项目-图形验证码实现

图形验证码实现:

1.先导入相应的包(一个生成图形验证码的库)
from utils.captcha.captcha import captcha
#导入django的相关的redis库,用于存储生成的图形验证码
from django_redis import get_redis_connection
# logging模块是Python内置的标准模块,主要用于输出运行日志,
# 可以设置输出日志的等级、日志保存路径、日志文件回滚等
import logging
logger=logging.getLogger('django');
2.然后在视图函数上写相应的代码
class ImageCode(View):
    def get(self,request,image_code):
        text, image = captcha.generate_captcha();#获取包对应的图形和文字内容,用text和image接收
        con_redis=get_redis_connection('verify_code')#调用redis的库
        redis_key='img_{}'.format(image_code)#生成一个redis的外键
        con_redis.setex(redis_key,300,text)#生成检验时间300秒,将外键很文本信息存入到redis数据库中
        logger.info('image code {}'.format(text))
        return HttpResponse(content=image,content_type='image/jpg')#将生成的图片映射到前台页面,
        # content_type表示图像类型的数据

3.然后在相应的js上面写相应的逻辑代码
let $img = $(".form-item .captcha-graph-img img");   // 获取图像
    genreate();#调用函数
    $img.click(genreate);#点击图片调用相应的函数
    function genreate() {
        let Simagecode=generateUUID(); //生成验证码
        let imageCodeUrl = 'http://127.0.0.1:8000/verification/image_code/'+ Simagecode + '/';//将验证码和随机数相结合
        $img.attr('src' , imageCodeUrl)#j将图像的生成的地址映射到前台
    }
     // 生成图片UUID验证码
    function generateUUID() {
      let d = new Date().getTime();
      if (window.performance && typeof window.performance.now === "function") {
          d += performance.now(); //use high-precision timer if available
      }
      let uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
          let r = (d + Math.random() * 16) % 16 | 0;
          d = Math.floor(d / 16);
          return (c == 'x' ? r : (r & 0x3 | 0x8)).toString(16);
      });
      return uuid;
    }
然后在相应的urls中配置相应的路由
path("image_code/<uuid:image_code>/",views.ImageCode.as_view(),name="image_code"),
在相应的setting中配置一个redis数据库,用于存放图像验证码
 # 配置redis的库,用来缓冲图形验证码
    'verify_code':{
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379/1",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值