1.用戶在項目前端,輸入手機號,而後點擊【獲取驗證碼】,將手機號發到post到後臺。javascript
2.後臺驗證手機號是否合法,是否已被佔用,若是經過驗證,則生成驗證碼,並經過運行腳本,讓短信運營商向該手機號,發送該驗證碼,若是沒經過驗證,則返回錯誤信息前端
3.用戶收到短信驗證碼之後,再次將全部信息post到後臺。java
4.後臺驗證各個數據,經過驗證則完成實名制認證,若是沒經過則返回錯誤信息。ajax
地址:https://www.yunpian.com/django
後臺管理控制檯頁面:其中最重要的信息是APIKEYjson
1.雲片網後臺的【測試】是沒有意義的,所謂的測試,就是直接給你手機發送一條短信,這算哪門子測試?後端
2.【簽名/模板設備】頁,【簽名管理】點擊【新增簽名】,到這裏會被提醒完善【開發者信息】,認證分爲開發者的【公司】和【我的】,如今是開發測試階段,能夠先選擇【我的】,【我的】要身份證的照片,提交照片。api
3.等待認證完成的短信通知,而後按照後臺的操做指引,在【簽名管理】頁【新增簽名】,在【模板管理】頁【新增模板】,這些都要等待雲片網的審覈,審覈經過會有短信通知。dom
4.在雲片網後臺設置ip白名單,將外網ip加入白名單async
獲取本機外網ip最簡單的方法,就是百度ip
在 項目目錄下 新建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('***(驗證碼)','*******(手機號)')
<!--發送按鈕倒計時代碼--> <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>
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)
from .views import ForCodeView ...... urlpatterns = [ ...... path('forcode/',ForCodeView.as_view(),name='forcode'), ]
#雲片網apikey APIKEY=‘你雲片網的apikey’
個人博客即將搬運同步至騰訊雲+社區,邀請你們一同入駐:https://cloud.tencent.com/developer/support-plan?invite_code=h8mmoufw70zz