django 发送手机验证码的示例代码


Posted in Python onApril 25, 2018

一、流程分析:

1.用户在项目前端,输入手机号,然后点击【获取验证码】,将手机号发到post到后台。

2.后台验证手机号是否合法,是否已被占用,如果通过验证,则生成验证码,并通过运行脚本,让短信运营商向该手机号,发送该验证码,如果没通过验证,则返回错误信息

3.用户收到短信验证码以后,再次将所有信息post到后台。

4.后台验证各个数据,通过验证则完成实名制认证,如果没通过则返回错误信息。

总结,一次实名验证,需要两次ajax+post

二、对接短信商:

1.在云片网端:

1.注册云片网

地址:https://www.yunpian.com/

后台管理控制台页面:其中最重要的信息是APIKEY

django 发送手机验证码的示例代码

2.开发者备案、新增签名、新增模板(模板管理)

1.云片网后台的【测试】是没有意义的,所谓的测试,就是直接给你手机发送一条短信,这算哪门子测试?

2.【签名/模板设备】页,【签名管理】点击【新增签名】,到这里会被提醒完善【开发者信息】,认证分为开发者的【公司】和【个人】,现在是开发测试阶段,可以先选择【个人】,【个人】要身份证的照片,提交照片。

3.等待认证完成的短信通知,然后按照后台的操作指引,在【签名管理】页【新增签名】,在【模板管理】页【新增模板】,这些都要等待云片网的审核,审核通过会有短信通知。

django 发送手机验证码的示例代码

4.在云片网后台设置ip白名单,将外网ip加入白名单

django 发送手机验证码的示例代码

获取本机外网ip最简单的方法,就是百度ip

django 发送手机验证码的示例代码

2.在django项目中写发送短信的脚本

在 项目目录下 新建utils目录 新建yunpian.py

import requests
class YunPian(object):
  def __init__(self,api_key):
    self.api_key=api_key
    self.single_send_url='https://sms.yunpian.com/v2/sms/single_send.json'

  def send_sms(self,code,mobile):
    parmas={
      'apikey':self.api_key,
      'mobile':mobile,
      'text':'【**网】您的验证码是[code]。如非本人操作,请忽略本短信'.format(code=code)
    }
    #text必须要跟云片后台的模板内容 保持一致,不然发送不出去!
    r=requests.post(self.single_send_url,data=parmas)
    print(r)

if __name__=='__main__':
  yun_pian=YunPian('***************(你的apikey)')
  yun_pian.send_sms('***(验证码)','*******(手机号)')

三、在项目中写发送手机验证码相关代码:

1.前端相关代码:

<!--发送按钮倒计时代码-->
<script type="text/javascript">
var countdown=60;
function settime(obj) {
  if (countdown == 0) {
    obj.removeAttribute("disabled");
    obj.value="免费获取验证码";
    countdown = 60;
    return;
  } else {
    obj.setAttribute("disabled", true);
    obj.value="重新发送(" + countdown + ")";
    countdown--;
  }
setTimeout(function() {
  settime(obj) }
  ,1000)
}

</script>


<!--手机号码输入框代码-->

<div class="form-group">
          <label for="mobile" class="col-lg-2 col-sm-2 control-label">手机号码:</label>
          <div class="col-lg-10">
            <div class="input-group m-bot15">
          <input type="text" class="form-control" id="mobile" name="mobile" placeholder="手机号码">
          <span class="input-group-btn">
             <input type="button" id="forcode" onclick="settime(this)" value="免费获取验证码" class="btn btn-success">
          </span>
            </div>
          <p class="help-block">请填写绑定手机号</p>
          </div>
        </div>


<!--向后台通过ajax发送手机号码数据-->
<script>
  $('#forcode').click(function () {
    $.ajax({
      cache:false,
      type:"POST",
      url:"{% url 'users:forcode' %}",
      data:{
        csrfmiddlewaretoken:$('[name="csrfmiddlewaretoken"]').val(),
        mobile:$("#mobile").val()
      },
      async:true,
      success:function (data) {
        alert(data)
      }
    })
  })
</script>

效果图:

django 发送手机验证码的示例代码

2.在users/views.py中写发送验证码相关代码:

import re
import random
from xyw.settings import APIKEY
from .models import VerifyCode


class ForCodeView(View):
  """获取手机验证码"""
  def post(self,request):
    mobile=request.POST.get('mobile','')
    if mobile:
      #验证是否为有效手机号
      mobile_pat=re.compile('^(13\d|14[5|7]|15\d|166|17\d|18\d)\d{8}$')
      res=re.search(mobile_pat,mobile)
      if res:
        #生成手机验证码
        code=VerifyCode()
        code.mobile=mobile
        c=random.randint(1000,9999)
        code.code=str(c)
        code.save()
        code=VerifyCode.objects.filter(mobile=mobile).first().code
        yunpian=YunPian(APIKEY)
        sms_status=yunpian.send_sms(code=code,mobile=mobile)
        msg=sms_status.msg
        return HttpResponse(msg)
      else:
        msg='请输入有效手机号码!'
        return HttpResponse(msg)
    else:
      msg='手机号不能为空!'
      return HttpResponse(msg)

3.在users/urls.py中:

from .views import ForCodeView
......

urlpatterns = [

  ......
  path('forcode/',ForCodeView.as_view(),name='forcode'),
]

4.在settings.py中增加代码:

#云片网apikey
APIKEY=‘你云片网的apikey'

至此,完成了发送手机验证码功能。

其实也有可以优化的地方:

1.虽然前端设置了60秒才可以重新发送,但是这个验证在后端也应该有,以防被有心人利用。

2.没有验证手机号码是否已经被发送过验证码

3.验证码没有生命周期,应该各一段时间让验证码失效

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python和shell实现的校验IP地址合法性脚本分享
Oct 23 Python
Python中的特殊语法:filter、map、reduce、lambda介绍
Apr 14 Python
python类继承用法实例分析
May 27 Python
Python读csv文件去掉一列后再写入新的文件实例
Dec 28 Python
Python通过调用mysql存储过程实现更新数据功能示例
Apr 03 Python
python3实现基于用户的协同过滤
May 31 Python
Python使用gRPC传输协议教程
Oct 16 Python
解决python ogr shp字段写入中文乱码的问题
Dec 31 Python
在Python中字典根据多项规则排序的方法
Jan 21 Python
在Tensorflow中查看权重的实现
Jan 24 Python
python环境下安装opencv库的方法
Mar 05 Python
pytorch MSELoss计算平均的实现方法
May 12 Python
python3+PyQt5实现自定义分数滑块部件
Apr 24 #Python
详解tensorflow载入数据的三种方式
Apr 24 #Python
关于Tensorflow中的tf.train.batch函数的使用
Apr 24 #Python
TensorFlow入门使用 tf.train.Saver()保存模型
Apr 24 #Python
Python使用 Beanstalkd 做异步任务处理的方法
Apr 24 #Python
Windows上使用Python增加或删除权限的方法
Apr 24 #Python
python编写暴力破解zip文档程序的实例讲解
Apr 24 #Python
You might like
php xml 入门学习资料
2011/01/01 PHP
PHP利用Cookie设置用户30分钟未操作自动退出功能
2017/07/03 PHP
Laravel创建数据库表结构的例子
2019/10/09 PHP
来自国外的页面JavaScript文件优化
2010/12/08 Javascript
Javascript面向对象编程(三) 非构造函数的继承
2011/08/28 Javascript
动态的改变IFrame的高度实现IFrame自动伸展适应高度
2012/12/28 Javascript
Javascript中string转date示例代码
2013/11/01 Javascript
iframe父页面获取子页面参数的方法
2014/02/21 Javascript
jQuery中JSONP的两种实现方式详解
2016/09/26 Javascript
jQuery的事件预绑定
2016/12/05 Javascript
bootstrap datetimepicker日期插件使用方法
2017/01/13 Javascript
javascript中join方法实例讲解
2019/02/21 Javascript
javascript实现图片轮播代码
2019/07/09 Javascript
bootstrap-table+treegrid实现树形表格
2019/07/26 Javascript
微信小程序框架的页面布局代码
2019/08/17 Javascript
JS实现音量控制拖动
2020/01/15 Javascript
简单介绍Python中的floor()方法
2015/05/15 Python
python3解析库pyquery的深入讲解
2018/06/26 Python
python通过http下载文件的方法详解
2019/07/26 Python
Python DataFrame一列拆成多列以及一行拆成多行
2019/08/06 Python
在pytorch中实现只让指定变量向后传播梯度
2020/02/29 Python
在django admin详情表单显示中添加自定义控件的实现
2020/03/11 Python
基于Python的OCR实现示例
2020/04/03 Python
可自定义箭头样式的CSS3气泡提示框
2016/03/16 HTML / CSS
CAT鞋美国官网:CAT Footwear
2017/11/27 全球购物
全球性的众包图形设计市场:DesignCrowd
2021/02/02 全球购物
物流专业自荐信
2014/05/23 职场文书
教师竞聘上岗演讲稿
2014/09/03 职场文书
高校师德师风自我剖析材料
2014/09/29 职场文书
小学班主任自我评价
2015/03/11 职场文书
公安机关起诉意见书
2015/05/20 职场文书
在人间读书笔记
2015/06/30 职场文书
校运会宣传稿大全
2015/07/23 职场文书
2015元旦感言
2015/12/09 职场文书
一级电子管军用接收机测评
2022/04/05 无线电
使用CSS定位HTML元素的实现方法
2022/07/07 HTML / CSS