• 博客系统-验证码相关


    前端相关

    <img class="validCode_img" src="/get_validCode_img/" alt="" width="160px" height="40px" title="点击更换验证码">
    
    前端src访问这个url会自动生成图片链接

    验证码刷新

    //url无刷新验证码
    $(".validCode_img").click(function () {
         this.src+="?";
    });

    url配置

    url(r'^get_validCode_img/',views.get_validCode_img),

    后端代码具体实现

    # 生成验证码函数
    def get_validCode_img(request):
        print("===================caonidaye,登陆页面执行")
        from io import BytesIO
        import random
        from PIL import Image,ImageDraw,ImageFont
        img = Image.new(mode="RGB", size=(120, 40),color=(random.randint(0, 255), random.randint(0, 255), random.randint(0, 255)))   #背景
        draw = ImageDraw.Draw(img,mode="RGB")     #生成一个画笔,可以写东西
        draw.point([100, 20], fill="black")         #画点-----(坐标,参数)
        draw.line((5,20,90,30),fill="black")        #画线-----(开始坐标,结束坐标;颜色参数)
        draw.line((10,20,50,30),fill="black")
        draw.arc((60,0,68,8),0,90,fill="red")      #画圆------(xxxxxxxxx)
        draw.arc((0,0,80,40),0,90,fill="red")
        font = ImageFont.truetype("blog/static/font/kumo.ttf",25)
        # draw.text([20,10],"python","purple",font=font)       #写文本  ----(坐标,文本,颜色,字体)
        valid_list = []
        for i in range(5):
            '''文本信息'''
            random_num = str(random.randint(0,9))
            random_lower_char = chr(random.randint(65,90))
            random_upper_char = chr(random.randint(97,122))
            random_char = random.choice([random_num,random_lower_char,random_upper_char])
            draw.text([5+i*24,10],random_char,(random.randint(0,255),random.randint(0,255),random.randint(0,255)),font=font)
            valid_list.append(random_char)     #写一次添加一次
    
    
        f = BytesIO()
        img.save(f,"png")    #刷到内存
        data = f.getvalue()   #从内存取值
        ########################################################################3
        valid_str = "".join(valid_list)   #将列吧拼接成字符串
        print(valid_str)
        request.session["keepValidCode"]=valid_str       #存到session中
        return HttpResponse(data)
  • 相关阅读:
    搭建nexus私服(maven)
    maven配置本地仓库(从本地仓库下载jar包到.m2仓库)
    关于引入多个jquery冲突的问题(附一个很好用的validate前端验证框架及使用方法)
    java excel导出
    Eclipse+Maven创建webapp项目 及部署在tomcat上
    solr添加IK分词和自己定义词库
    将Mysq数据导入solr索引库
    solr +zookeeper+Jetty 集群搭建
    solr +zookeeper+tomcat 集群搭建
    如何用Maven创建web项目(具体步骤)转载
  • 原文地址:https://www.cnblogs.com/52-qq/p/8669241.html
Copyright © 2020-2023  润新知