热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

django项目中使用手机号登录

本文使用聚合数据的短信接口,需要先获取到申请接口的appkey和模板id项目目录下创建ubtils文件夹,定义返回随机验证码和调取短信接口的函数function.py文件se













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


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


function.py文件



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


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": "167106", # 短信模板ID,请参考个人中心短信模板设置
"tpl_value": "#code#=%s"%num,
# 变量名和变量值对。如果你的变量名或者变量值中带有#&=中的任意一个特殊符号,请先分别进行urlencode编码后再传递,详细说明>
"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\') == \'1\':

tel
= request.POST.get(\'user_tel\')
print(tel)
range_num
= function.range_num(4); # 5454

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\') == \'1\':
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())


前端登录的表单



{#手机登陆的表单#}
"post">

"text" name="user_tel" placeholder="请输入手机号">

"text" name="validcode" placeholder="请输入短信验证码">


class="am-g">
"yanzhengma" type="button" value="获取验证码"/>
"nowYanzhengma" color: rgba(128, 0, 0, 1)">"display: none;" type="button" value=""/>
class="submit " type="button" id="btn_login" value="登录"/>




{
#手机登陆的表单#}


前端登录的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。


 














推荐阅读
  • 这个报错出现在userDao里面,sessionfactory没有注入。解决办法:spring整合Hibernate使用test测试时要把spring.xml和spring-hib ... [详细]
  • C#爬虫Fiddler插件开发自动生成代码
    哈喽^_^一般我们在编写网页爬虫的时候经常会使用到Fiddler这个工具来分析http包,而且通常并不是分析一个包就够了的,所以为了把更多的时间放在分析http包上,自动化生成 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 深入解析Django CBV模型的源码运行机制
    本文详细探讨了Django CBV(Class-Based Views)模型的源码运行流程,通过具体的示例代码和详细的解释,帮助读者更好地理解和应用这一强大的功能。 ... [详细]
  • 本文探讨了在使用 ClickOnce 部署方式时遇到的自动更新失败问题,包括本地安装与服务器安装的不同表现,并提供了详细的解决方案。 ... [详细]
  • PHP 5.4.8 编译安装指南
    本文详细介绍了如何在Linux环境下编译安装PHP 5.4.8,并配置为FastCGI模式运行。包括所需依赖包的安装、源代码下载、编译配置及启动服务等步骤。 ... [详细]
  • 本文详细介绍如何在Spring Boot项目中集成和使用JPA,涵盖JPA的基本概念、Spring Data JPA的功能以及具体的操作步骤,帮助开发者快速掌握这一强大的持久化技术。 ... [详细]
  • 微信小程序支付官方参数小程序中代码后端发起支付代码支付回调官方参数文档地址:https:developers.weixin.qq.comminiprogramdeva ... [详细]
  • 深入探讨Web服务器与动态语言的交互机制:CGI、FastCGI与PHP-FPM
    本文详细解析了Web服务器(如Apache、Nginx等)与动态语言(如PHP)之间通过CGI、FastCGI及PHP-FPM进行交互的具体过程,旨在帮助开发者更好地理解这些技术背后的原理。 ... [详细]
  • 本文介绍了JSP的基本概念、常用标签及其功能,并通过示例详细说明了如何在JSP页面中使用Java代码。 ... [详细]
  • 本文深入解析了Django框架中的MVT(Model-View-Template)设计模式,详细阐述了其工作原理和应用流程。通过分析URL模式、视图、模型和模板等关键组件,读者将全面理解Django应用程序的架构体系,掌握如何高效地构建和管理Web应用。 ... [详细]
  • 在Django中提交表单时遇到值错误问题如何解决?
    在Django项目中,当用户提交包含多个选择目标的表单时,可能会遇到值错误问题。本文将探讨如何通过优化表单处理逻辑和验证机制来有效解决这一问题,确保表单数据的准确性和完整性。 ... [详细]
  • VSCode中实现大型项目函数跳转的方法
    在处理大型代码项目时,简单的C/C++插件往往无法满足需求。本文介绍如何通过配置GNU Global等工具,在VSCode中实现高效的函数跳转。 ... [详细]
  • Python 中变量类型的确定与默认类型解析
    本文详细探讨了 Python 中变量类型的确定方式及其默认类型,帮助初学者更好地理解变量类型的概念。 ... [详细]
  • 本文详细介绍了如何在 Django 项目中使用 Admin 管理后台,包括创建超级用户、启动项目、管理数据模型和修改用户密码等步骤。 ... [详细]
author-avatar
棋牌
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有