登录随机验证码

  • python代码
import random
# Image:用来生成图片  ImageDraw:用来在图片上"写字"  ImageFont:字体样式
from PIL import Image, ImageDraw, ImageFont
# BytesIO能保存数据,并且在取数据时会以二进形式返回, StingIO在取数据时会以字符串形式返回
from io import BytesIO, StringIO


# 获取随机三个rgb参数
def get_color():
    return random.randint(64, 255), random.randint(64, 255), random.randint(64, 255)


def get_color1():
    return random.randint(0, 196), random.randint(0, 196), random.randint(0, 196)


def get_code(request):
    # 生成图片对象,参数一传“RGB”,参数二传图片尺寸(元组), 参数三传颜色
    img_obj = Image.new("RGB", (262, 33), get_color())
    # 生成一个画笔对象,该画笔可以在图片上随意图画
    img_draw = ImageDraw.Draw(img_obj)
    # 生成一个字体对象
    img_font = ImageFont.truetype("static/font/fang.ttf", 30)
    # 为图片的每个像素设置随机颜色
    for x in range(262):
        for y in range(33):
            img_draw.point((x, y), fill=get_color1())
    code = ""
    # 循环四次,生成一个4个字符的随机字符串
    for i in range(4):
        random_int = str(random.randint(0, 9))
        random_lower = chr(random.randint(97, 122))
        random_upper = chr(random.randint(65, 90))
        # 获取一个随机的字母或数字
        temp_code = random.choice([random_int, random_lower, random_upper])
        # 将获取的随机字符写到图片上(x,y坐标, 字符, 颜色, 字体)
        img_draw.text((60 + i * 40, 0), temp_code, get_color(), img_font)
        code += temp_code
    print(code)
    # 将最终生成的字符保存到session中,方便用户登录时验证码验证
    request.session["code"] = code
    # 生成一个BytesIO对象,该对象可看成文件句柄
    io_obj = BytesIO()
    # 将图片数据存入内存管理器中,需指定图片格式,否则报错
    img_obj.save(io_obj, "png")
    # 将二进制格式的图片数据发送给前端渲染
    return HttpResponse(io_obj.getvalue())
  • html代码
 <div class="form-group">
     <label for="id_code">验证码</label>
     <div class="row">
            <div class="col-md-6 col-sm-6">
                <input type="text" class="form-control" id="id_code">
            </div>
            <div class="col-md-6 col-sm-6">
                <img src="/get_code/" alt="" width=100% height=33px id="id_img">
            </div>
      </div>
 </div>
  • js代码
// 用户点击验证码图片就能更换图片,只需在img标签的src属性后面加字符就可以
$("#id_img").on("click", function () {
   let old_url = $(this).attr("src");
   $(this).attr("src", old_url+"?")
});

 

posted @ 2019-06-20 22:24  hengshan  阅读(236)  评论(0编辑  收藏  举报