本文使用聚合数据的短信接口,需要先获取到申请接口的appkey和模板id

项目目录下创建ubtils文件夹,定义返回随机验证码和调取短信接口的函数

function.py文件

import random
import re
# 随机数
def range_num(num):
# 定义一个种子,从这里面随机拿出一个值,可以是字母
seeds = ""
# 定义一个空列表,每次循环,将拿到的值,加入列表
random_num = []
# choice函数:每次从seeds拿一个值,加入列表
for i in range(num):
random_num.append(random.choice(seeds))
# 将列表里的值,变成四位字符串
return "" . join(random_num)#

sendMsg.py文件

import json, urllib
from urllib.parse import urlencode
# 发送短信
def request2(mobile,num, m="GET"):
appkey = '6bba3e7dffa71b79483002e1d92f4d00'
url = "http://v.juhe.cn/sms/send"
params = {
"mobile": mobile, # 接收短信的手机号码
"tpl_id": "", # 短信模板ID,请参考个人中心短信模板设置
"tpl_value": "#code#=%s"%num,
# 变量名和变量值对。如果你的变量名或者变量值中带有#&=中的任意一个特殊符号,请先分别进行urlencode编码后再传递,<a href="http://www.juhe.cn/news/index/id/50" target="_blank">详细说明></a>
"key": appkey, # 应用APPKEY(应用详细页查询)
"dtype": "", # 返回数据的格式,xml或json,默认json
}
params = urlencode(params)#mobile=15038062130&tpl_id=166467&tpl_value=%23code%23%3d431515&key=dabf6ecaebfa9554395dad7dcc6be7c8
if m == "GET":
f = urllib.request.urlopen("%s?%s" % (url, params))
else:
f = urllib.request.urlopen(url, params)
content = f.read()#{"reason":"操作成功","result":{"sid":"201906200911371223162juhe6hy","fee":1,"count":1},"error_code":0}
res = json.loads(content)#json转字典
if res:
error_code = res["error_code"]
if error_code == 0:
# 成功请求
return 'ok'
# print(res["result"])
else:
return "%s:%s" % (res["error_code"], res["reason"])
# print("%s:%s" % (res["error_code"], res["reason"]))
else:
return "request api error"

路由

# 手机验证码登录
path('loginTel/', login.loginTel,name='loginTel'),

方法

from blog.utils import sendMsg
from blog.utils import function # 引入自定义的验证码 # 手机验证登陆
def loginTel(request):
res = {'status': None, 'info': None}
# 点击发送短信执行以下程序
if request.POST.get('sendSms') == '': tel = request.POST.get('user_tel')
print(tel)
range_num = function.range_num(4); # request.session['validcode'] = range_num result = sendMsg.request2(tel, range_num, "GET")
# result='ok' if result == 'ok':
res['status'] = 1
# res['info']='发送成功%s'%range_num
res['info'] = '发送成功'
print(res)
return HttpResponse(json.dumps(res)) # 把这个结果告诉给前台,ajax
else:
res['status'] = 0
res['info'] = '发送失败'
return HttpResponse(json.dumps(res)) # 把这个结果告诉给前台,ajax # 点击登录按钮执行以下程序:
if request.POST.get('dosubmit') == '':
validcode_form = request.POST.get('validcode')
validcode_session = request.session.get('validcode') # 获取session if validcode_form:
if validcode_form != validcode_session:
res['status'] = 0
res['info'] = '短信验证码不正确'
return HttpResponse(json.dumps(res)) # 把这个结果告诉给前台,ajax
else:
res['status'] = 0
res['info'] = '短信验证码不存在'
return HttpResponse(json.dumps(res)) # 把这个结果告诉给前台,ajax # 写判断手机号是否在会员表中
member_obj = Member.objects.filter(member_tel=request.POST.get('user_tel')).first()
if member_obj:
request.session['member_id'] = member_obj.member_id
request.session['member_name'] = member_obj.member_name
res['status'] = 1
res['info'] = '登录成功'
return HttpResponse(json.dumps(res)) # 把这个结果告诉给前台,ajax
return render(request, 'blog/loginTel.html', locals())

前端登录的表单

{#手机登陆的表单#}
<form method="post"> <input type="text" name="user_tel" placeholder="请输入手机号"> <input type="text" name="validcode" placeholder="请输入短信验证码"> <div class="am-g">
<input id="yanzhengma" type="button" value="获取验证码"/>
<input id="nowYanzhengma" style="display: none;" type="button" value=""/>
<input class="submit " type="button" id="btn_login" value="登录"/> </div>
</form> {#手机登陆的表单#}

前端登录的jquery

{#手机号登陆的jquery#}
//校验用户名
$("#btn_login").click(function () {
var user_tel = $.trim($("input[name='user_tel']").val());
var validcode = $.trim($("input[name='validcode']").val()); $.post("/blog/loginTel/", {
"user_tel": user_tel,
"validcode": validcode,
"dosubmit": 1,
"csrfmiddlewaretoken": "{{ csrf_token }}"
}, function (data) {
if (data['status'] == 1) {
layer.msg("登录成功!即将跳转至首页~");
location.href = "{% url 'index' %}";
} else { layer.msg(data['info']);
} return false;
}, "json");
});
//点击获取验证码按钮
$("#yanzhengma").click(function () {
getSmsCode();
}); //获取短信验证码
function getSmsCode() { var user_tel = $.trim($("input[name='user_tel']").val());//得到页面里的手机号码
var reguser = /^[1][3-8]\d{9}$/;
if (user_tel == "") {
layer.msg("请填写手机号码");
return false;
}
if (!reguser.test(user_tel)) {
layer.msg("手机号码格式不正确");
return false;
}
{#$("#yanzhengma").off('click');#}
$.post("/blog/loginTel/", {
"user_tel": user_tel,
'sendSms': 1,
"csrfmiddlewaretoken": "{{ csrf_token }}"
}, function (data) {
if (data['status'] == 1) {
timeout();
layer.msg(data['info']);
} else {
layer.msg(data['content']);
}
}, 'json');
} var sec = 60;
var interval = null; //开启定时器
function timeout() {
interval = setInterval(run, 1000);
} function run() {
if (sec >= 1) {
sec--;
$("#yanzhengma").hide();
$("#nowYanzhengma").show();
$("#nowYanzhengma").val("倒计时(" + sec + ")s"); } else {
$("#yanzhengma").off('click');
$('#yanzhengma').on("click", function (event) {
getSmsCode();
});
$("#yanzhengma").show();
$("#nowYanzhengma").hide();
clearInterval(interval);//关闭定时器
sec = 60;
} } {#手机号登陆的jquery结束#}

前端效果

done。

django项目中使用手机号登录的更多相关文章

  1. Django项目中集成第三方登录时出现的错误

    原以为是被反爬 没想到 总结:这里的http应该是https协议,以后要更加小心 了,不能犯这种低级错误

  2. Django项目中使用qq第三方登录。

    使用qq登录的前提是已经在qq互联官网创建网站应用并获取到QQ互联中网站应用的APP ID和APP KEY 1,建路由 # qq登录 path('loginQq/',qq.loginQq,name=' ...

  3. 【技术博客】JWT的认证机制Django项目中应用

    开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了.我们认为这样的经验是有必要记录下来的,因此就有了[技术博客]. JWT的认证机制Django项目中应用 这篇技术博客基于软 ...

  4. 转:C4项目中验证用户登录一个特性就搞定

    转:C4项目中验证用户登录一个特性就搞定   在开发过程中,需要用户登陆才能访问指定的页面这种功能,微软已经提供了这个特性.     // 摘要:    //     表示一个特性,该特性用于限制调用 ...

  5. [翻译]在Django项目中添加谷歌统计(Google Analytics)

    原文:<Google Analytics tracking code into Django projects, the easy way> 对我来说,制作一个可扩展的Django应用随时 ...

  6. Django项目中使用Redis

    Django项目中使用Redis DjangoRedis 1 redis Redis 是一个 key-value 存储系统,常用于缓存的存储.django-redis 基于 BSD 许可, 是一个使 ...

  7. 擦他丫的,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了!

    擦 ,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了! 问题在于我使用的谷歌浏览器,默认使用了缓存,导致每次访问同一个url时,都返回的是缓存里面的东西.通过谷歌 ...

  8. django 项目中使用多数据库 multiple databases

    假如在一个django项目中使用到了不只一个数据库, 其实这在大一点的工程中很常见,比如主从库 那么会涉及到如下一些东西 1, 定义 在settings中的DATABASE中定义会使用到的数据,比如除 ...

  9. django 项目中的 favicon.ico 处理

    django 项目中的 favicon.ico 处理  (django == 2.0.6) 1. 引入模块: from django.views.generic.base import Redirec ...

随机推荐

  1. (三)Java数据结构和算法——冒泡、选择、插入排序算法

    一.冒泡排序 冒泡算法的运作规律如下: ①.比较相邻的元素.如果第一个比第二个大,就交换他们两个. ②.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.这步做完后,最后的元素会是最大的数( ...

  2. 查看Oracle表空间以及用户与其默认表空间情况

    Oracle中一个表空间可能是多个用户的默认表空间,下面语句统计了用户及其默认表空间情况,如果用户多个,用户之间通过逗号分隔. select t.default_tablespace, to_char ...

  3. 【Spring Boot学习之二】WEB开发

    环境 Java1.8 Spring Boot 1.3.2 一.静态资源访问 动静分离:动态服务和前台页面图片分开,静态资源可以使用CDN加速;Spring Boot默认提供静态资源目录位置需置于cla ...

  4. Oracle RAC 创建实例出错(非+DATA目录)的简单处理

    今天进行oracle的rac测试 发现开发同事没有写好 oracle rac的设置.  创建完之后就会报错了 因为自己对oracle 的RAC 不太熟悉 不太会用.. 所以用 一个比较简单的办法. a ...

  5. kafka web端管理工具 kafka-manager【转发】

    1,下载与安装 $ git clone https://github.com/yahoo/kafka-manager.git $ cd kafka-manager $ ./sbt clean dist ...

  6. spring整合mybatis报.UnsatisfiedDependencyException错误

    tomcat启动报org.springframework.beans.factory.UnsatisfiedDependencyException:错误 org.springframework.bea ...

  7. 长乐国庆集训Day5-2

    T1 彩虹 题目 [题目描述] Mr.Raju和他的一个大家庭外出度假,他们想要乘着彩虹欣赏周围的景色,但是这样最会有一些问题. 在他们家族中,如果一个人想要骑上彩虹,那么他喜欢的所有人和喜欢他的所有 ...

  8. Symfony框架笔记

    控制器获取前端传入的参数 $parameters = $request->request; $data = $parameters->all(); 引用静态资源(js.css.img) 使 ...

  9. STM8L052C6T6液晶LCD驱动过程

    首先还是必要的说明,鄙人经验有限,如发现问题还请不吝赐教,反馈到邮箱mr.li.ming@qq.com 使用的液晶屏 单片机引脚 液晶的COM1-COM4分别对应单片机LCD_COM0-LCD_COM ...

  10. 插件部署【BE、BP、UI】

    1.BE插件部署 XML部署位置:D:\yonyou\U9V50\Portal\bin: DLL部署位置:D:\yonyou\U9V50\Portal\ApplicationServer\Libs; ...