- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章flask框架实现修改密码和免密登录功能由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
数据库部分:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
#重置密码
def
reset_pass(phone,password):
conn,cursor
=
get_conn()
sql
=
"update userdata set userpass='"
+
password
+
"' where userphone='"
+
phone
+
"'"
try
:
print
(
"正在修改密码..."
)
resetflag
=
cursor.execute(sql)
conn.commit()
close_conn(conn,cursor)
if
(resetflag
=
=
1
):
print
(
"修改成功"
)
return
1
else
:
print
(
"修改失败!"
)
return
0
except
:
print
(
"系统错误...修改密码失败!"
)
return
0
|
路由部分:
1
2
3
4
5
6
7
8
9
10
11
12
|
#用户修改密码
@app
.route(
'/resetpass'
,methods
=
[
'GET'
,
'POST'
])
def
resetpass():
userphone
=
request.values.get(
'userphone'
)
resetpass
=
request.values.get(
'resetpass'
)
print
(
"路由获得手机号:"
+
userphone
+
"\n"
)
print
(
"路由获得新密码:"
+
resetpass
+
"\n"
)
flag
=
sql.reset_pass(userphone,resetpass)
if
(flag
=
=
1
):
return
jsonify({
"data"
:
1
})
else
:
return
jsonify({
"data"
:
0
})
|
html页面:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
<!DOCTYPE html>
<
html
lang
=
"en"
>
<
head
>
<
meta
charset
=
"UTF-8"
>
<
meta
name
=
"viewport"
content
=
"width=device-width, initial-scale=1.0"
>
<
meta
http-equiv
=
"X-UA-Compatible"
content
=
"ie=edge"
>
<
title
>树懒电影---重置您的密码</
title
>
<
style
type
=
"text/css"
>
#resetform{
margin-top: 350px;
margin-left: 750px;
}
</
style
>
</
head
>
<
body
>
<
form
method
=
"post"
id
=
"resetform"
>
<
tr
>
<
td
><
input
type
=
"text"
id
=
"userphone"
value
=
""
placeholder
=
"输入您的手机号码"
></
td
>
</
tr
><
br
>
<
tr
>
<
td
><
input
type
=
"password"
id
=
"resetpass1"
value
=
""
placeholder
=
"输入您的新密码"
></
td
>
</
tr
><
br
>
<
tr
>
<
td
><
input
type
=
"password"
id
=
"resetpass2"
value
=
""
placeholder
=
"再次输入您的新密码"
></
td
>
</
tr
><
br
>
<
tr
>
<
td
><
input
type
=
"reset"
value
=
"清空"
></
td
>
<
td
><
input
type
=
"button"
id
=
"resetbtn"
onclick
=
"resetpass()"
value
=
"提交"
></
td
>
</
tr
>
</
form
>
</
body
>
</
html
>
<
script
src
=
"../static/js/jquery.min.js"
></
script
>
<
script
type
=
"text/javascript"
>
function resetpass(){
var userphone=document.getElementById("userphone").value
var resetpass1=document.getElementById("resetpass1").value
var resetpass2=document.getElementById("resetpass2").value
var submit_flag=1
//判空
if((userphone.length==0)||(resetpass1.length==0)||(resetpass2.length==0)){
submit_flag=0
alert("请把信息填写完整!")
}
//判断密码一致性
if(resetpass2!=resetpass1){
submit_flag=0
alert("两次填写的密码不一致")
document.getElementById("resetpass1").focus();
}
//判断手机号
if(userphone.length!=11){
submit_flag=0
alert("手机号码应为11位!")
document.getElementById("userphone").focus();
}
var regu = /^1[3456789]\d{9}$/
if(!(regu.test(userphone)) ){
submit_flag=0
alert("手机号码格式有误!")
document.getElementById("userphone").focus();
}
//判断密码格式
if(!((resetpass1.length>=6)&&resetpass1.length<=18))
{
submit_flag=0
alert("密码长度应该为6-16位!")
document.getElementById("resetpass1").focus();
}
var regex = new RegExp('(?=.*[0-9])(?=.*[a-zA-Z]).{6,18}');
part_pass=resetpass1.split(" ")
if((!(regex.test(resetpass1))) || part_pass.length!=1)
{
submit_flag=0
alert("密码为数字+英文字母 且不可以包含空格!")
document.getElementById("resetpass1").focus();
}
//发起请求
if(submit_flag==1)
{
$.ajax({
url:"/resetpass",
data:{userphone:userphone,resetpass:resetpass2},
success: function (data) {
if (data.data==1)
{
alert("密码修改成功!")
window.open("/",'_self')
}
else
{
alert("修改密码失败!请重试")
}
},
error: function (xhr, type, errorThrown) {
// print("ajax请求失败!")
}
})
}
// alert(submit_flag)
}
</
script
>
|
html代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
<!DOCTYPE html>
<
html
lang
=
"en"
>
<
head
>
<
meta
charset
=
"UTF-8"
>
<
meta
name
=
"viewport"
content
=
"width=device-width, initial-scale=1.0"
>
<
meta
http-equiv
=
"X-UA-Compatible"
content
=
"ie=edge"
>
<
link
rel
=
"stylesheet"
href
=
"../static/css/login.css"
rel
=
"external nofollow"
>
<
script
src
=
"../static/js/jquery-1.7.2.min.js"
></
script
>
<
script
src
=
"../static/js/register.js"
></
script
>
<
title
>树懒电影登录</
title
>
<
script
>
</
script
>
</
head
>
<
body
>
<
div
id
=
"container"
>
<
div
id
=
"container-child"
>
<
div
id
=
"img-div"
><
img
src
=
"../static/img/shulan.png"
></
div
>
<
div
id
=
"login-div"
>
<
div
>
<
p
class
=
"p-title"
>登录您的树懒电影</
p
>
<
form
id
=
"login-form"
method
=
"post"
>
<
div
class
=
"input-d"
>
<
input
class
=
"input-text"
type
=
"text"
name
=
"userphone"
id
=
"userphone"
placeholder
=
"请输入您的账号"
>
</
div
>
<
div
class
=
"input-d"
>
<
input
class
=
"input-text"
type
=
"password"
name
=
"password"
id
=
"password"
placeholder
=
"请输入您的密码"
>
</
div
>
<
div
class
=
"div-input"
>
<
div
>
<
input
type
=
"checkbox"
value=“1” class=“remeber”
onclick
=
"onClickHander(this)"
>
<
label
>记住密码</
label
>
</
div
>
</
div
>
<
button
type
=
"button"
class
=
"login-button"
onclick
=
"login_()"
>登 录</
button
>
<
div
class
=
"footer"
> <
a
href
=
"http://127.0.0.1:5000/regis"
rel
=
"external nofollow"
>注册</
a
> | <
a
href
=
"http://127.0.0.1:5000/reset"
rel
=
"external nofollow"
>忘记密码</
a
></
div
>
</
form
>
</
div
>
</
div
>
</
div
>
</
div
>
</
body
>
</
html
>
<
script
>
var cb=0
function onClickHander(obj) {
if(obj.checked==true){
cb=1
// alert(cb)
}else{
cb=0
// alert(cb)
}
}
function login_(){
var userphone=document.getElementById("userphone").value
var password=document.getElementById("password").value
// alert(cb)
$.ajax({
url: "/web_login",
data: {
userphone:userphone,password:password,cb:cb
},
success: function (data) {
//正常验证失败弹窗
if (data.data == 0)
alert("账号或密码错误!")
//验证成功,返回response
if (data.data != 0)
window.open("http://127.0.0.1:5000/show","_self")
},
error: function (xhr, type, errorThrown) {
print("登录js,验证账号密码ajax请求失败!")
}
})
}
</
script
>
|
Python路由 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
#免密登录
@app
.route(
'/web_login/'
,methods
=
[
'GET'
,
'POST'
])
def
web_login():
userphone
=
request.values.get(
'userphone'
)
password
=
request.values.get(
'password'
)
cb
=
request.values.get(
'cb'
)
print
(
"是否记住密码: "
+
cb)
#cb的返回值类型是 str 字符串
# print(type(cb))
print
(
"登录账号:"
+
userphone
+
" "
+
"密码:"
+
password)
res
=
sql.web_login(userphone,password)
if
(res
=
=
True
):
session[
'userphone'
]
=
userphone
if
(cb
=
=
"1"
):
print
(
"开始存储cookie登录账号:"
+
userphone
+
" "
+
"密码:"
+
password)
resp
=
make_response(
'储存cookie'
)
resp.set_cookie(
'cookphone'
, userphone, max_age
=
3600
*
24
*
15
)
resp.set_cookie(
'cookpass'
, password, max_age
=
3600
*
24
*
15
)
print
(
"登录成功且用户选择记住密码,返回response"
)
return
resp
#登录成功且用户选择记住密码,返回response
else
:
print
(
"登录成功 返回 1 状态码"
)
return
jsonify({
"data"
:
1
})
# 登录成功 返回 1 状态码
else
:
print
(
"登录失败 返回 0 状态码"
)
return
jsonify({
"data"
:
0
})
#登录失败 返回 0 状态码
|
数据库验证登录 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
# 用户(web)登录验证
def
web_login(userphone, password):
cursor
=
None
conn
=
None
res
=
[]
if
(userphone
=
=
None
or
password
=
=
None
):
return
False
conn, cursor
=
get_conn()
sql
=
"select userphone,userpass from userdata where '"
+
userphone
+
"'=userphone and '"
+
password
+
"'=userpass "
res
=
query(sql)
conn.commit()
if
(
len
(res)
=
=
0
):
print
(
"登陆失败(WEB)"
)
close_conn(conn, cursor)
return
False
else
:
close_conn(conn, cursor)
print
(
"登陆成功(WEB)"
)
return
True
|
以上就是flask框架实现修改密码和免密登录功能的详细内容,更多关于flask 修改密码和免密登录的资料请关注我其它相关文章! 。
原文链接:https://www.cnblogs.com/rainbow-1/p/14800247.html 。
最后此篇关于flask框架实现修改密码和免密登录功能的文章就讲到这里了,如果你想了解更多关于flask框架实现修改密码和免密登录功能的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在尝试为我的用户提供使用 Google 或 Facebook 登录的选项。到目前为止,我找到了一个实现 Google 登录流程的示例,但如果我可以在同一 Activity 中实现类似的 Faceb
我有一个网页,它对用户是否登录很敏感。我使用的是 Google 登录 Javascript SDK。当用户到达此页面时,我想显示一个插页式广告(“正在加载...”),然后 1)如果用户已登录则呈现页面
我用 digitalocean 创建了一个 droplet,并使用 apt install mariadb-server 命令安装了 mariadb。现在我想使用 php 连接到我的服务器,我使用这个
这个问题在这里已经有了答案: Inno Setup - Signing fails with "Sign Tool failed with exit code 0x1" (2 个回答) 3年前关闭。
我正在尝试使用他们的新 API 实现 google 登录:https://developers.google.com/identity/sign-in/web/ 登录和注销工作正常。我的问题是我不知道
我的应用程序具有谷歌登录、Facebook 登录和 braintree 集成。 我已将以下代码放入 appdelegate.swift 中: func application(_ applicatio
我有一个 Flask 应用程序,最近在我的登录/退出表单中实现了 Flask-Login: @account.route('/sign-in', methods=['POST', 'GET']) de
friend 们,我是初学者级别的 ios swift 学习者。我一直在尝试在我的试用应用程序中进行谷歌登录。根据来自谷歌开发人员和其他教程的资源,我成功地使用 UIView 进行了登录。然后我试图在
我正在使用 Ionic 在 Codeigniter/Ion_Auth/codeigniter-restclient 之上构建登录系统,当我尝试从“ionic 服务器”登录时,登录可以正常工作,但对 L
在 Docker 文件中我有这个 FROM ubuntu RUN apt update && apt -y upgrade RUN apt install -y sudo # Setup ops us
对于 Java 开发,我使用 Slf4j 和 Logback。 Logger logger = LoggerFactory.getLogger(HelloWorld.class); logger.de
在 Scala 应用程序中进行日志记录的好方法是什么?与语言哲学一致的东西,不会使代码困惑,并且维护成本低且不引人注目。以下是基本要求列表: 简单 不会使代码困惑。 Scala 以其简洁而著称。我不希
我正在尝试将我的登录名转换为 Retrofit2 我的旧 LoginActivity: public class LoginActivity extends Activity { private st
我正在尝试让 google+ 登录在 android 上运行。我的问题是,每当我使用 eclipse 运行它时,google 开发站点上提供的示例都能完美运行。当我签署 apk 并在我的设备上手动安装
这个问题已经有答案了: JS Simple but Safe Login? [closed] (1 个回答) 已关闭 6 年前。 我正在尝试使用 JavaScript 创建登录页面。它实际上只是一个带
其他章节请看: react 高效高质量搭建后台系统 系列 登录 本篇将完成 登录模块 。效果和 spug 相同: 需求 如下:
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 1 年前。
我在使用 ReactJs 中的 facebook-login 组件时遇到问题,代码与文档中的完全一样,但仍然无法正常工作。你能帮我找出我做错了什么吗? import React, { Componen
我有一个项目,其中包含许多具有自己的日志记录的“工具”类。这些日志文件是在应用程序启动时创建的,但在使用之前一直为空。 是否可以告诉logback在启动时不应该创建空文件?但是仅在使用它们时? 不知何
我正在创建一个需要用户授权才能访问某些功能的网站。我目前正在研究用户如何创建帐户以及如何利用 session 来授权他们的登录。用户信息存储在名为 user 的 MySQL 表中,其中可能包括用户名和
我是一名优秀的程序员,十分优秀!