flask框架實(shí)現(xiàn)修改密碼和免密登錄功能
修改密碼功能
數(shù)據(jù)庫部分:
#重置密碼 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("系統(tǒng)錯誤...修改密碼失??!") return 0
路由部分:
#用戶修改密碼 @app.route('/resetpass',methods=['GET', 'POST']) def resetpass(): userphone=request.values.get('userphone') resetpass=request.values.get('resetpass') print("路由獲得手機(jī)號:"+userphone+"\n") print("路由獲得新密碼:" + resetpass + "\n") flag=sql.reset_pass(userphone,resetpass) if(flag==1): return jsonify({"data":1}) else: return jsonify({"data":0})
html頁面:
<!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="輸入您的手機(jī)號碼"></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(); } //判斷手機(jī)號 if(userphone.length!=11){ submit_flag=0 alert("手機(jī)號碼應(yīng)為11位!") document.getElementById("userphone").focus(); } var regu = /^1[3456789]\d{9}$/ if(!(regu.test(userphone)) ){ submit_flag=0 alert("手機(jī)號碼格式有誤!") document.getElementById("userphone").focus(); } //判斷密碼格式 if(!((resetpass1.length>=6)&&resetpass1.length<=18)) { submit_flag=0 alert("密碼長度應(yīng)該為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("密碼為數(shù)字+英文字母 且不可以包含空格!") document.getElementById("resetpass1").focus(); } //發(fā)起請求 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代碼:
<!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 rel="external nofollow" >注冊</a> | <a 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) { //正常驗(yàn)證失敗彈窗 if (data.data == 0) alert("賬號或密碼錯誤!") //驗(yàn)證成功,返回response if (data.data != 0) window.open("http://127.0.0.1:5000/show","_self") }, error: function (xhr, type, errorThrown) { print("登錄js,驗(yàn)證賬號密碼ajax請求失??!") } }) } </script>
Python路由
#免密登錄 @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 狀態(tài)碼") return jsonify({"data": 1}) # 登錄成功 返回 1 狀態(tài)碼 else: print("登錄失敗 返回 0 狀態(tài)碼") return jsonify({"data":0}) #登錄失敗 返回 0 狀態(tài)碼
數(shù)據(jù)庫驗(yàn)證登錄
# 用戶(web)登錄驗(yàn)證 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("登陸失?。╓EB)") close_conn(conn, cursor) return False else: close_conn(conn, cursor) print("登陸成功(WEB)") return True
以上就是flask框架實(shí)現(xiàn)修改密碼和免密登錄功能的詳細(xì)內(nèi)容,更多關(guān)于flask 修改密碼和免密登錄的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
現(xiàn)代Python編程的四個關(guān)鍵點(diǎn)你知道幾個
這篇文章主要為大家詳細(xì)介紹了Python編程的四個關(guān)鍵點(diǎn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-02-02Ubuntu18.04中Python2.7與Python3.6環(huán)境切換
這篇文章主要為大家詳細(xì)介紹了Ubuntu18.04中Python2.7與Python3.6環(huán)境切換,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-06-06通過python繪制華強(qiáng)買瓜的字符畫視頻的步驟詳解
要把華強(qiáng)賣瓜做成字符視頻大概分為三步,通過讀取視頻,把每一幀轉(zhuǎn)為字符畫,接著把字符畫表現(xiàn)出來,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-11-11如何解決Visdom全藍(lán),不顯示內(nèi)容問題
這篇文章主要介紹了如何解決Visdom全藍(lán),不顯示內(nèi)容問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06keras實(shí)現(xiàn)多種分類網(wǎng)絡(luò)的方式
這篇文章主要介紹了keras實(shí)現(xiàn)多種分類網(wǎng)絡(luò)的方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06Python實(shí)現(xiàn)字符串的逆序 C++字符串逆序算法
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)字符串的逆序,C++將字符串逆序輸出,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04