摘要:在導(dǎo)航條中,右側(cè)有登錄和注冊兩個(gè)鏈接,儲存用戶數(shù)據(jù)的模型也有了,現(xiàn)在我們來實(shí)現(xiàn)登錄和注冊的功能。
在導(dǎo)航條中,右側(cè)有登錄和注冊兩個(gè)鏈接,儲存用戶數(shù)據(jù)的Users模型也有了,現(xiàn)在我們來實(shí)現(xiàn)登錄和注冊的功能。
先來看注冊功能的實(shí)現(xiàn),新建一個(gè)視圖函數(shù),如下:
@app.route("/register/") def register(): return render_template("register.html")
在導(dǎo)航條模板base.html中,為注冊添加鏈接,使用url_for函數(shù)將其href屬性值修改為register.html,如下:
接下來我們要去制作register.html了,這部分是基礎(chǔ)的html/css知識,控件也是用的Bootstrap框架,最終注冊頁http://127.0.0.1:5000/register/的效果圖如下(結(jié)尾貼出代碼):
register.html中的表單控件,我們設(shè)置了其方法為POST,注冊按鈕的type為submit,這樣點(diǎn)擊提交按鈕的時(shí)候,瀏覽器就會以POST方法去請求當(dāng)前網(wǎng)址,但我們的視圖函數(shù)默認(rèn)只能接受GET方法,因此我們要為其添加POST方法,并使用flask中的request對象獲取表單提交的數(shù)據(jù),最終視圖函數(shù)代碼如下:
@app.route("/register/", methods=["GET", "POST"]) def register(): if request.method == "GET": return render_template("register.html") else: username = request.form.get("username") password1 = request.form.get("password1") password2 = request.form.get("password2") print(username, password1, password2) return " "
request.form.get方法需要傳入表單控件的name屬性的值,這樣就能獲取到對應(yīng)的填入到表單中的值了,為了演示,我們在結(jié)尾將其打印了出來,結(jié)果顯示無誤,說明后端已經(jīng)獲取到了POST提交的數(shù)據(jù)。
登陸頁面也是一樣的原理,拿register.html簡單修改成login.html,模仿register再增加一個(gè)login視圖函數(shù),然后訪問http://127.0.0.1:5000/login/,效果如下:
結(jié)尾貼上register.html的內(nèi)容:
{% extends "base.html" %} {% block static_files %} {% endblock %} {% block page_name %}注冊{% endblock %} {% block body_part %}{% endblock %}注冊
代碼中引入的register_login.css是register.html和login.html通用的,其內(nèi)容如下:
h3{ text-align: center; padding-top: 10px; } .form{ width: 400px; margin: 0 auto; } form.form > div{ padding: 8px; }
此外還對導(dǎo)航條模板做了簡單的調(diào)整,第一是增加了一個(gè)block,給每個(gè)繼承它的html一個(gè)放自定義css文件的地方,第二是在body中增加了一個(gè)div塊,即register.html和login.html中間白色的內(nèi)容區(qū)域,最終base.html代碼如下:
{% block static_files %}{% endblock %}{% block page_name %}{% endblock %}-HarpQA {% block body_part %} {% endblock %}
base.css也添加了 文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。 轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/41250.html.body-container{
width: 600px;
background: white;
margin: 0 auto;
border-radius: 5px;
}
摘要:前端渲染可以減輕服務(wù)器端的開銷,但是首屏的渲染會加長時(shí)間后端渲染增加服務(wù)器的開銷,但是減少客戶端展示的時(shí)間 1 注冊、登錄和退出 1.1 用戶注冊、登錄 配置模板引擎、mongoDB數(shù)據(jù)庫驅(qū)動、靜態(tài)文件路徑和post請求解析中間件 統(tǒng)一api.js路由的數(shù)據(jù)返回格式 // 統(tǒng)一返回?cái)?shù)據(jù)格式 var responseData; // 每次請求進(jìn)來都進(jìn)行初始化 router.use(f...
摘要:本文講解的就是授權(quán)登錄的教程。從拿到的用戶信息如下圖最終效果參與文章如何設(shè)計(jì)第三方授權(quán)登錄的用戶表第三方授權(quán)登錄的時(shí)候,第三方的用戶信息是存數(shù)據(jù)庫原有的表還是新建一張表呢答案這得看具體項(xiàng)目了,做法多種,請看下文。 showImg(https://segmentfault.com/img/remote/1460000018372844?w=1210&h=828); 需求:在網(wǎng)站上想評論一...
摘要:上面的寫法有個(gè)問題點(diǎn)擊按鈕發(fā)送請求后,客戶端一直收不到響應(yīng),就會報(bào)錯(cuò)其實(shí)傳送的時(shí)是一個(gè)異步的過程,里面還沒執(zhí)行完,外面就已經(jīng)執(zhí)行了,這邊可以用來解決下這個(gè)問題內(nèi)部返回一個(gè)對象,成功調(diào)用函數(shù),失敗調(diào)用函數(shù),這邊就默認(rèn)它會成功。 今天來研究一個(gè)小小的功能。當(dāng)我們進(jìn)入一個(gè)網(wǎng)站,它怎么判斷我是不是它的用戶?讓用戶登錄唄,如果它能正常登錄,它就是我的用戶唄?你有沒想過它是怎么判斷我是不是它用戶的...
摘要:通過的定制字段的輸入小部件,將文本框的寬度設(shè)置為列,而不是默認(rèn)的列。為此將創(chuàng)建一個(gè)新的應(yīng)用程序,其中包含處理用戶賬戶相關(guān)的所有功能。該函數(shù)將會為通過了身份驗(yàn)證的用戶對象創(chuàng)建會話。 《Python編程:從入門到實(shí)踐》筆記。本篇記錄如何創(chuàng)建用戶注冊系統(tǒng),如何實(shí)現(xiàn)用戶輸入自己的數(shù)據(jù)。 1. 前言 在本篇中,我們將: 創(chuàng)建一些表單,讓用戶能夠添加主題和條目,以及編輯既有的條目; 實(shí)現(xiàn)一個(gè)身份...
閱讀 1834·2021-11-24 09:39
閱讀 2302·2021-09-30 09:47
閱讀 4169·2021-09-22 15:57
閱讀 1888·2019-08-29 18:36
閱讀 3589·2019-08-29 12:21
閱讀 599·2019-08-29 12:17
閱讀 1276·2019-08-29 11:25
閱讀 734·2019-08-28 18:26