zoukankan      html  css  js  c++  java
  • 图形验证码---pillow

    图片验证码逻辑

    1. 客户端发起GET连接请求,并随机生成UUID,绑定图片
      • UUID:通用唯一识别码(Universally Unique Identifier),目的,是让分布式系统中的所有元素,都能有唯一的辨识信息,每个人都可以创建不与其它人冲突的UUID
    2. 服务端生成图片验证码,图片存入内存并返回到客户端
    3. 服务端存储源字符串到session中,也可以存入缓存中,例memcachedredis
    4. 客户端表单填写验证码原值
    5. 移出表单框时间触发异步post请求验证,访问时,图片uuid作为属性绑定到表单属性中,作为post提交的数据一部分
    6. 服务端验证时通过UUIDkey,表单值为value进行图片验证码校验

    图片验证码使用

      下载pillow

    pip install pillow

      在使用的时候需要设置pillow需要的字体。需要复制到django项目中

    设置字体文件的路径

     setting.py

    生成图片

     urls.py
     views.py

    vue生成uuid

     regist.vue

    vue请求图片验证码

    复制代码
    <template>
      <div>
          
          <p><img @click="refresh()" :src="'http://127.0.0.1:8000/user/generate_image_code/' + uuid" /></p>
          <p>验证码<input type="text" v-model="code"></p>
          
      </div>
    </template>
    
    <script>
    import axios from 'axios'
    export default {
      name:"regist",
      data() {
        return {
          code:'',
          uuid:'',
        }
      },
      methods: {
        generate_uuid: function() {
          var d = new Date().getTime();
          if (window.performance && typeof window.performance.now === "function") {
            d += performance.now(); //use high-precision timer if available
          }
          var uuid = "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(
            /[xy]/g,
            function(c) {
              var r = (d + Math.random() * 16) % 16 | 0;
              d = Math.floor(d / 16);
              return (c == "x" ? r : (r & 0x3) | 0x8).toString(16);
            }
          );
          return uuid;
        },
        refresh(){
          this.uuid = this.generate_uuid()
        }
      },
      mounted() {
        this.uuid = this.generate_uuid()
      },
    }
    </script>
    复制代码

    带图片验证码的用户注册

     regist.vue
     setting.py
     user/urls.py
     user/serializers.py
     user/model.py
     user/views.py
  • 相关阅读:
    mysql 设置自增主键id的起始值
    一文搞定MySQL的事务和隔离级别
    SpringBoot2.0整合Redis
    Redis Cluster搭建高可用Redis服务器集群
    为什么单线程的Redis这么快?
    Spring Boot使用AOP在控制台打印请求、响应信息
    Spring boot集成spring session实现session共享
    SpringBoot项目在IntelliJ IDEA中实现热部署
    Spring Boot入门-快速搭建web项目
    一篇文章搞定SpringMVC参数绑定
  • 原文地址:https://www.cnblogs.com/ZS1314/p/12422681.html
Copyright © 2011-2022 走看看