python實現注冊登錄--flask框架web開發實踐


使用python搭建一個web服務器,然后使用python語言來開發后台服務。Flask是一個用Python編寫的Web應用程序框架。常見的服務包括,包括http的各種類型請求,如get、post等常規請求。對於web開發,不同頁面之間的跳轉、數據傳輸通信、網頁存儲、緩存等是基礎知識。

下面我們都使用pycharm來進行python實踐。Pycharm選擇免費的社區版下載即可。在pycharm里安裝flask的方法如下:

在項目的setting設置菜單里選擇解釋器窗口,點擊右側的+號尋找可以安裝的第三方庫。選中Flask,點擊安裝即可。視網絡速度快慢,一般都比較快的可以完成安裝。

2)flask搭建服務器

flask是web開發框架,簡單易學,因此用flask來搭建web服務也非常簡單。

在pycharm新建一個項目,命名為weblogin1117,然后新建一個python文件,命名為main.py。在代碼中輸入如下代碼:

from flask import Flask #導入Flask類 app=Flask(__name__) #實例化並命名為app實例

if __name__=="__main__": app.run(port=2020,host="127.0.0.1",debug=True) #調用run方法,設定端口號,啟動服務

此時打開瀏覽器,在瀏覽器地址輸入127.0.0.1:2020運行,頁面會提示報錯,因為此時還沒有任何內容輸出,僅僅是web服務的搭建。

3)flask開發簡單網頁

如果在main.py文件中開始加入一些內容,並使得能在網頁上顯示,就進入了我們常見的web開發模式了。由於main.py為python文件,而不是我們常用的HTML,因此無法直接使用html語言來寫界面和內容。

(3)flask開發簡單網頁

如果在main.py文件中開始加入一些內容,並使得能在網頁上顯示,就進入了我們常見的web開發模式了。由於main.py為python文件,而不是我們常用的HTML,因此無法直接使用html語言來寫界面和內容。

對於web開發和運行而言,在瀏覽器地址欄那我們知道是url,也就是請求的網頁地址,如http://127.0.0.1/index或者http://127.0.0.1/home/user、或者http://127.0.0.1/index/news.html這些模式。在使用一些服務器語言來實現web開發時,url構建和定位使用了面向對象或者函數方式。如http://127.0.0.1/home/user,可以分拆理解:http://127.0.0.1為服務器地址,默認為請求index方法頁面。地址后面的/home/user可以理解為定位到服務器地址文件夾里home類里的user方法頁面。

在使用flask框架來開發時,這種url的構建和定位也是非常重要的。我們先來看一個簡單案例:

from flask import  Flask
app=Flask(__name__)

@app.route('/')
def index():
    return 'welcome to my webpage!'

if __name__=="__main__":
    app.run(port=2020,host="127.0.0.1",debug=True)

代碼中使用了裝飾器來制定路由url,具體寫法如下:

@app.route('/')    #調用route路由方法,括號里給定參數,/符號默認為首頁
@app.route('/home/user')    #調用route路由方法,/home/user定位到訪問user方法頁面

在定制了路由url后,還需要給定一個實現方法,使用python定義函數的方式來實現,如上index函數,返回一個字符串welcome to my webpage。也就是當路由url定位到首頁時,就調用這個index函數,此時就會在瀏覽器上輸出這個字符串內容。

 

 

flask開發簡單網站

到此為止,我們使用flask框架實現了一個網頁的開發,還可以傳輸數據。但網站肯定是由多個網頁構成的,多個網頁之間還要實現相互鏈接訪問。首先在main.py文件增加多個網頁的路由和調用函數。

根據路由設定,在templates文件夾下新增兩個網頁文件,login.html和regist.html。

 flask框架在使用這個模板函數時,默認去尋找項目文件夾下的templates文件夾里的html文件。因此我們需要先新建一個templates文件夾,然后在里面新建一個html文件,我們用注冊登錄項目舉例子:


項目結構如下

 

 
         

 

代碼如下,主要包括三部分,main.py login.html regist.html

導入模塊

 
         

python使用Flask需要導入Flask模塊,如果沒有這個模塊就參見前面的鏈接去安裝。使用mysql需要導入pymysql模塊,這個具體是什么,請參見鏈接描述。總之,python需要用到特定的模塊的時候,需要去導入模塊,本例具體導入的內容如下所示

#導入數據庫模塊
import pymysql
#導入Flask框架,這個框架可以快捷地實現了一個WSGI應用
from flask import Flask
#默認情況下,flask在程序文件夾中的templates子文件夾中尋找模塊
from flask import render_template
#導入前台請求的request模塊
from flask import request   
import traceback  
#傳遞根目錄
app = Flask(__name__)

路由訪問靜態文件

 
         

Flask創建服務器后,照着前面圖片的文件目錄,通過下面的路由就能通過服務器訪問靜態的html文件,代碼如下所示:


#默認路徑訪問登錄頁面
@app.route('/')
def login():
    return render_template('login.html')
 
#默認路徑訪問注冊頁面
@app.route('/regist')
def regist():
    return render_template('regist.html')
此時在瀏覽器中通過localhost:5000(Flask默認端口為5000)就能訪問login.html文件,localhost:5000/regist就能訪問regist.html。


處理前台請求及對數據庫進行操作
跟所有的web服務思路一樣,獲取前台的請求,根據不同的請求路由執行不同的函數內容。這里以注冊為例,當表單填寫完后,點擊注冊按鈕,數據向后台請求,請求路由為/registuser。python根據相對應的路由執行函數,這里函數處理的內容是把前台的用戶名和密碼插入到數據庫中(前提是已經在數據庫中創建好了user表)。插入成功就跳轉到登錄頁面,插入失敗就返回注冊失敗的內容。登錄的邏輯內容也類似,就不再細述,具體代碼如下:
————————————————

#獲取注冊請求及處理
@app.route('/registuser')
def getRigistRequest():
#把用戶名和密碼注冊到數據庫中
 
    #連接數據庫,此前在數據庫中創建數據庫TESTDB
    db = pymysql.connect("localhost","root","123456","TESTDB" )
    # 使用cursor()方法獲取操作游標
    cursor = db.cursor()
    # SQL 插入語句
    sql = "INSERT INTO user(user, password) VALUES ("+request.args.get('user')+", "+request.args.get('password')+")"
    try:
        # 執行sql語句
        cursor.execute(sql)
        # 提交到數據庫執行
        db.commit()
         #注冊成功之后跳轉到登錄頁面
        return render_template('login.html')
    except:
        #拋出錯誤信息
        traceback.print_exc()
        # 如果發生錯誤則回滾
        db.rollback()
        return '注冊失敗'
    # 關閉數據庫連接
    db.close()

#獲取登錄參數及處理
@app.route('/login')
def getLoginRequest():
#查詢用戶名及密碼是否匹配及存在
    #連接數據庫,此前在數據庫中創建數據庫TESTDB
    db = pymysql.connect("localhost","root","123456","TESTDB" )
    # 使用cursor()方法獲取操作游標
    cursor = db.cursor()
    # SQL 查詢語句
    sql = "select * from user where user="+request.args.get('user')+" and password="+request.args.get('password')+""
    try:
        # 執行sql語句
        cursor.execute(sql)
        results = cursor.fetchall()
        print(len(results))
        if len(results)==1:
            return '登錄成功'
        else:
            return '用戶名或密碼不正確'
        # 提交到數據庫執行
        db.commit()
    except:
        # 如果發生錯誤則回滾
        traceback.print_exc()
        db.rollback()
    # 關閉數據庫連接
    db.close()
    
 
#使用__name__ == '__main__'是 Python 的慣用法,確保直接執行此腳本時才
#啟動服務器,若其他程序調用該腳本可能父級程序會啟動不同的服務器
if __name__ == '__main__':
    app.run(debug=True)
    
基本登錄注冊功能已實現:連接數據庫的時候請匹配自己數據庫的密碼及數據庫名稱

創建數據庫代碼如下:
mysql> create table user(id int(10) not null ,user varchar(20) not null,password varchar(20));
ERROR 1046 (3D000): No database selected
mysql> use testdb;
Database changed
mysql> create table user(id int(10) not null ,user varchar(20) not null,password varchar(20));
Query OK, 0 rows affected, 1 warning (0.05 sec)

mysql> drop database  testdb;
Query OK, 1 row affected (0.04 sec)

mysql> create database   TESTDB;
Query OK, 1 row affected (0.02 sec)

mysql> create table user(user varchar(20) not null,password varchar(20));
ERROR 1046 (3D000): No database selected
mysql> use testdb;
Database changed
mysql> create table user(user varchar(20) not null,password varchar(20));
Query OK, 0 rows affected (0.06 sec)

數據庫表中的數據是已經在網頁注冊了2次了,因此2個賬號和密碼被寫入數據庫中。

 
         

 

 

 








完整代碼如下:

main.py

#導入數據庫模塊
import pymysql
#導入Flask框架,這個框架可以快捷地實現了一個WSGI應用
from flask import Flask
#默認情況下,flask在程序文件夾中的templates子文件夾中尋找模塊
from flask import render_template
#導入前台請求的request模塊
from flask import request
import traceback
#傳遞根目錄
app = Flask(__name__)


# 默認路徑訪問登錄頁面
@app.route('/')
def login():
return render_template('login.html')


# 默認路徑訪問注冊頁面
@app.route('/regist')
def regist():
return render_template('regist.html')


# 獲取注冊請求及處理
@app.route('/registuser')
def getRigistRequest():
# 把用戶名和密碼注冊到數據庫中

# 連接數據庫,此前在數據庫中創建數據庫TESTDB
#db = pymysql.connect("localhost", "root","123456", "testdb")
db = pymysql.connect(host="127.0.0.1", user="root", password="123456", database="testdb")
# 使用cursor()方法獲取操作游標
cursor = db.cursor()
# SQL 插入語句
sql = "INSERT INTO user(user, password) VALUES ('" + request.args.get('user') + "', '" + request.args.get(
'password') + "')"
#VALUES ('"+request.args.get('user')+"', '"+request.args.get('password')+"')
try:
# 執行sql語句
cursor.execute(sql)
# 提交到數據庫執行
db.commit()
# 注冊成功之后跳轉到登錄頁面
return render_template('login.html')
except:
# 拋出錯誤信息
traceback.print_exc()
# 如果發生錯誤則回滾
db.rollback()
return '注冊失敗'
# 關閉數據庫連接
db.close()


# 獲取登錄參數及處理
@app.route('/login')
def getLoginRequest():
# 查詢用戶名及密碼是否匹配及存在
# 連接數據庫,此前在數據庫中創建數據庫TESTDB
db = pymysql.connect("localhost", "root", "123456", "TESTDB")
# 使用cursor()方法獲取操作游標
cursor = db.cursor()
# SQL 查詢語句
#sql = "select * from user where user=" + request.args.get('user') + " and password=" + request.args.get(
# 'password') + ""
user = str(request.args.get('user'))
password = str(request.args.get('password'))
sql = "select * from user where user= '%s' and password= %s" % (user, password)
sql = "INSERT INTO user(user, password) VALUES ('%s','%s')" % (user, password)
try:
# 執行sql語句
cursor.execute(sql)
results = cursor.fetchall()
print(len(results))
if len(results) == 1:
return '登錄成功'
else:
return '用戶名或密碼不正確'
# 提交到數據庫執行
db.commit()
except:
# 如果發生錯誤則回滾
traceback.print_exc()
db.rollback()
# 關閉數據庫連接
db.close()


# 使用__name__ == '__main__' Python 的慣用法,確保直接執行此腳本時才
# 啟動服務器,若其他程序調用該腳本可能父級程序會啟動不同的服務器
if __name__ == '__main__':
app.run(debug=True)

前台頁面

 
         

在前台頁面中只需創建基本的表單內容,method使用get,登錄和注冊的action分別為/login、/registuser,代碼如下所示


login.html 如下:
<!--登錄模塊--!>
<!DOCTYPE html>
<html lang="en">
<head>
<title></title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="css/style.css" rel="stylesheet">
</head>
<body>
<form method="get" action='/login'>
<label>用戶名:<input type="text" name="user" value=""></label><br>
<label>密碼:<input type="password" name="password" value=""></label><br>
<input type="submit" value="登錄">
</form>
</body>
</html>

regist.html如下

<!--注冊模塊--!>
<!DOCTYPE html>
<html lang="en">
<head>
<title></title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="css/style.css" rel="stylesheet">
</head>
<body>
<form method="get" action='/registuser'>
<label>用戶名:<input type="text" name="user" value=""></label>
<label>密碼:<input type="password" name="password" value=""></label>
<input type="submit" value="注冊">
</form>
</body>
</html>

運行程序后顯示如下:

 

 



准備好了,然后再來啟動web服務,瀏覽器直接刷新后獲得如下效果:

注冊接口url:127.0.0.1:5000/regist

 

 

 登錄的url為:http://127.0.0.1:5000

 

注冊成功頁面顯示:
(備注:注冊成功后跳轉到登錄頁面,url的鏈接也包括剛注冊的賬號密碼 127.0.0.1:5000/registuser?user=123456&password=123456

 

 中途遇到的錯誤:

bug1:   db = pymysql.connect("localhost", "root","123456", "testdb")

修改1:db = pymysql.connect(host="127.0.0.1", user="root", password="123456", database="testdb")


bug2:#sql = "select * from user where user=" + request.args.get('user') + " and password=" + request.args.get( 'password') + ""
修改2:
user = str(request.args.get('user'))
password = str(request.args.get('password'))
sql = "select * from user where user= '%s' and password= %s" % (user, password)
sql = "INSERT INTO user(user, password) VALUES ('%s','%s')" % (user, password)
感謝前人栽樹:

 

 
         

 


 

 
         

 

 

 
目前只能實現到跳轉到登錄頁,輸入賬號密碼登錄未成功,后面的代碼有誤還未來得及修改,如果伙伴們發現錯誤,請糾正一些,謝謝大家~
前面的內容除了自己實現的,部分抄至以下鏈接:
python上手--flask框架web開發實踐 - 知乎 (zhihu.com)

源碼鏈接如下:

https://blog.csdn.net/qq_34964418/article/details/105404677


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM