成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

盤點Python網頁開發輕量級框架Flask知識(下篇)

開發 后端
本文著重講解了Flask的最基礎的用法,Flask是一個十分優秀的web開發框架,它可以十分迅速的開發出web應用,但是它需要依賴眾多的包才能完善更多的功能。

[[408569]]

前言

今天來給大家說一個Python的輕量級web開發框架-------Flask,為什么要推薦它呢?當然是因為它夠輕量級了,開發迅速是它的特點,當然它也有缺點,不過這里不說,因為既用它又說它差感覺不好。上篇文章我們說了一半的內容,盤點Python網頁開發輕量級框架Flask知識(上篇),這篇文章繼續補全剩下的一半內容,一起來學習下吧~

11.request操作

這是一個專門用來操作網頁請求的模塊,今天我們圍繞這個來具體講解。

1)request.method

它是request中的請求方法,一般我們用的比較多的便是get和post,由于get 和post需要配合表單一起使用,在這里我們暫時不講前端的內容,只做簡單的演示。

一、get請求

可通過設置它的methods參數來指定請求方式。

  1. @app.route('/get', methods = ['GET','POST']) 
  2. def get(): 
  3.     if request.method == 'GET'
  4.         return '這是一個GET請求' 
  5.     else
  6.         return '這是一個其它請求' 

二、post請求

  1. @app.route('/post', methods = ['POST','GET']) 
  2. def post(): 
  3.     if request.method == 'POST'
  4.         return '這是一個POST請求' 
  5.     else
  6.         return '這是一個其它請求' 

2)request.args

記錄get請求中的查詢參數,一般用于查詢,搜索網址

  1. https://www.kugou.com/yy/html/search.html#searchType=song&searchKeyWord=不謂俠 

它會返回get請求中的參數,比如請求上面的url,它的請求參數便是:

  1. searchType=song&searchKeyWord=不謂俠 

使用方法:

  1. request.args['keyword'
  2. request.args.get('keyword'

3)request.form

記錄請求中的表單數據,一般用于表單提交。比如我們注冊網站時經常需要進行表單提交。


我們可以使用獲取表單中的內容:

  1. request.form['keyword'
  2. request.form.get('keyword'

4)reuqest.values

返回請求中的參數和表單,這個用的比較少,暫不細說。

5)request.cookies

獲取網頁中的cookies的所有信息,也可以只獲取cookies中的一個參數的值。

  1. request.cookies['keyword'
  2. request.cookies.get('keyword'

6)request.headers

返回請求網頁頭部信息,返回一個列表。

  1. request.headers['keyword'
  2. request.headers.get('keyword'

7)request.url、path、script_root、base_url、url_root

  1. request.url:返回請求中的網頁地址 
  2.  
  3. request.path:返回網頁存放地址 
  4.  
  5. request.script_root:返回腳本根目錄 
  6.  
  7. request.base_url:返回請求相對地址 
  8.  
  9. request.url_root:返回請求網頁根目錄 

8)request.data

返回請求的數據

  1. request.data #返回一個字節類型的值 

9)request.files

文件上傳必備,屬于提交表單的類型,所以這是個post類型的請求方式,我們可以使用files的file字段來設置:

  1. @app.route('/upload',methods=['GET','POST']) 
  2. def upload(): 
  3.     if request.method == 'POST'
  4.         f = request.files['file'
  5.         filename = secure_filename(f.filename) #需要設置安全文件類型 
  6.         #f.save(os.path.join('app/static',filename))兩種保存方式 
  7.         f.save('app/static/'+str(filename)) 
  8.         return 'ok' 
  9.     else
  10.         return 'fail' 

10)request.json

返回json格式的數據

11)request.environ

返回環境變量的鍵值

12)request.remote_addr

返回客戶端的訪問ip地址

13)request.host

返回host信息

12.上下文與請求鉤子

1)上下文

可能大部分人對這個概念比較難以琢磨,先來說說上下文,什么是上下文?一說起上下文,我猜大家第一時間一定會想起with,想到with大家肯定會想起上下文的模塊contexlib以及魔法方法enter 和exit,可以說,它是將復雜的事情簡單化的一個神器的裝飾器,我是這樣理解的。那么再來看看flask的上下文。

一、應用程序上下文

它作用于flask應用中,可以用作程序實例和存儲臨時變量,它可分為兩種:

  1. g:處理請求時用作臨時存儲的對象,每次請求都會重設這個變量 
  2.  
  3. current_app: 當前程序實例 

二、請求上下文

顧名思義,它用于網絡請求中,它也有兩種。

  1. request:請求對象 
  2. Session:存儲會話 

2)鉤子

再來看看鉤子,什么是鉤子?這一點是我們先要搞清楚的,鉤子其實就是在我們進行請求時,它規范了我們的請求內容和請求方式以及請求時該做什么,什么時候做,具體做哪些事,起到了一個承上啟下的作用,所以,它很有用處。

一、在處理第一個請求前運行,可以用來連接數據庫進行查詢操作

  1. before_first_request 

二、在處理每個請求前運行,可以進行權限校驗

  1. before_request 

三、在每個請求結束后自動處理返回的響應數據

  1. after_request 

四、在每個請求結束后自動異常并將異常對象作為參數傳到函數中

  1. teardown_request 

五、在視圖函數中注冊一個函數,會在請求結束后運行

  1. after_this_request 

說完了這么多那么它們該怎么用了,接下來請看我表演:

  1. @app.before_first_request 
  2. def first(): 
  3.     print('我是第一運行的'
  4.  
  5. @app.before_request 
  6. def every(): 
  7.     print('我又來了'
  8.  
  9. @app.after_request 
  10. def recv(res): 
  11.     res.headers['Content-Type']='application/json' #更改響應頭部數據 
  12.     return res 
  13.  
  14. @app.route('/start/<string:id>'
  15. def start(id): 
  16.     g.use=request.cookies.get('user'
  17.     if id==g.use: 
  18.         return request.url 
  19.     else
  20.         return request.cookies 
  21.  
  22. ac= app.app_context() #應用上下文管理器 
  23. ac.push() #進 
  24. print(ac) 
  25. a = current_app 
  26. print(a) 
  27. ac.pop() #出 
  28. print(ac) 
  29.  
  30. with app.app_context() as f: 
  31.     b= current_app 
  32.     print(b) 
  33.     print(f) 

13.藍圖

從上面的事例我們可以看出,隨著我們開發的東西越來越多,把所有東西放在一個文件里,很顯然不切實際。

我們嘗試著使用模塊調用,于是我編寫了兩個Python程序,用來調用:

demo1.py

  1. from flask import Flask 
  2. app=Flask(__name__) 
  3. @app.route('/kj'
  4. def df(): 
  5.     return 'hello world' 
  6. @app.route('/index'
  7. def lk(): 
  8.     return 'efhsfj' 

demo2.py

  1. from flask import Flask,request 
  2. from demo1 import * 
  3. @app.route('/'
  4. def login(): 
  5.     return request.url 
  6. if __name__ == '__main__'
  7.     app.run(debug=True

這里demo2是可以成功調用demo1的,但是了,它無法操作demo1的變量以及一些實例,換言之就是只能調用,無法控制改變,于是這個時候藍圖就派上用場了,那么讓我們來看看吧。

demo3.py

  1. from flask import Flask 
  2. from demo4 import root 
  3. from demo5 import admin 
  4. app=Flask(__name__) #應用實例 
  5. @app.route('/'
  6. def lo(): 
  7.     return '1111' 
  8. app.register_blueprint(root,url_prefix='/') #藍圖對象和藍圖掛載點 
  9. app.register_blueprint(root,url_prefix='/root')  
  10. app.register_blueprint(root,url_prefix='/admin')  
  11. app.register_blueprint(admin,url_prefix='/'
  12. app.register_blueprint(admin,url_prefix='/admin')  
  13. app.register_blueprint(admin,url_prefix='/root')  
  14. if __name__ == '__main__'
  15.     app.run(debug=True

demo4.py

  1. from flask import Flask,Blueprint 
  2. root=Blueprint('root',__name__) #藍圖名稱和藍圖所在的模塊 
  3. @root.route('/login'
  4. def b1(): 
  5.     return 'hello' 
  6. @root.route('/index'
  7. def b2(): 
  8.     return 'world' 

demo5.py

  1. from flask import Flask,Blueprint 
  2. admin=Blueprint('admin',__name__) #藍圖名稱和藍圖所在的模塊 
  3. @admin.route('/ff'
  4. def bw(): 
  5.     return 'ergdsfg' 
  6. @admin.route('/gg'
  7. def be(): 
  8.     return 'gtergsdf' 

藍圖的精髓無非就是將多個模塊引入到一個主模塊中使用,相當于我們自己在寫模塊并把它當到藍圖中供調用。多個藍圖中如果有相同方法可用藍圖視圖函數來區分各自的方法。

14.視圖

一提到視圖,相信大家能想到它的意思,比如mysql數據庫中的視圖,道理其實都是互通的,并不會有太大的差別,只是功能不一樣罷了。創建視圖的方式也很簡單,都繼承自flask的views類。

1)類視圖

  1. from flask.views import View 
  2. def ff(): 
  3.     return 'ok' 
  4. class st(View): 
  5.     def dispatch_request(self): #必須實現這個方法 
  6.         return "任性的90后boy" 
  7. # 類視圖通過add_url_rule方法和url做映射 
  8. app.add_url_rule(rule='/ff',view_func=st.as_view('tt')) 

2)方法視圖

  1. from flask.views import MethodView 
  2. def gg(): 
  3.     return 'ok' 
  4. class login(MethodView): 
  5.     #當客戶端通過get方法進行訪問的時候執行的函數 
  6.     def get(self): 
  7.         return 'get' 
  8.     # 當客戶端通過post方法進行訪問的時候執行的函數 
  9.     def post(self): 
  10.         email = request.form.get("user"
  11.         password = request.form.get("pass"
  12.         if user== 'gffsadff' and pass== '4fsaferwf'
  13.             return "登錄成功" 
  14.         else
  15.             return "登陸失敗" 
  16.  
  17. # 通過add_url_rule添加類視圖和url的映射,并且在as_view方法中指定該url的名稱,方便url_for函數調用 
  18. app.add_url_rule('/gg',view_func=login.as_view('lg')) 

15.補充

1)全局對象

  1. with app.test_request_context(): 
  2.     print('我是第一個運行的'

看到這你應該知道它是干嘛的了吧,沒錯。

它是整個應用中最先啟動的,可以用來做一個提醒界面啥的。

2)路由別名

  1. @app.route('/<path:url>',endpoint='name1') #路由別名為name1 
  2. def first_flask(url):  
  3.     print(url_for('name1',url=url)) #如果設置了url參數,url_for(別名,加參數) 
  4.     return redirect(url_for('get'))#重定向 

3)添加路由規則

  1. def fl(): 
  2.     return 'ok3'  
  3. #app.add_url_rule(rule=訪問的url,endpoint=路由別名,view_func=視圖名稱,methods=請求方法) 
  4. app.add_url_rule(rule='/kj',endpoint='name2',view_func=fl,methods=['GET']) 

4)創建路由的其它方式

無需使用裝飾器的中央url映射方法,十分方便,要想實現它需創建三個文件:

myapp.py

  1. from flask import Flask 
  2. import views 
  3. app = Flask(__name__) 
  4. @app.route('/'
  5. def ll(): 
  6.     return 'index' 
  7.  
  8. @app.route('/use/<usename>'
  9. def use(usename): 
  10.     return usename 

views.py

  1. def ll(): 
  2.     return 'index' 
  3. def use(usename): 
  4.     return usename 

main.py

  1. from myapp import views 
  2. from flask import Flask 
  3. app=Flask(__name__) 
  4. app.add_url_rule('/', view_func=views.ll) 
  5. app.add_url_rule('/use/<usename>', view_func=views.use) 
  6. if __name__ == '__main__'
  7.     app.run(debug=True

5)常用狀態碼

  1. 200:請求正確 
  2. 404: 路徑錯誤 
  3. 405: 請求方式錯誤 
  4. 500: 服務器錯誤 
  5. 302: 重定向 
  6. 301 :永久重定向 

16.總結

本文著重講解了Flask的最基礎的用法,Flask是一個十分優秀的web開發框架,它可以十分迅速的開發出web應用,但是它需要依賴眾多的包才能完善更多的功能。

 

責任編輯:姜華 來源: Python爬蟲與數據挖掘
相關推薦

2021-06-26 10:03:35

Python框架Flask

2023-06-13 13:38:00

FlaskPython

2020-11-11 12:13:59

JS

2022-08-10 12:21:07

PythonWebBottle

2012-05-21 21:34:51

iOS

2011-08-15 10:45:11

iPhone開發delegate

2021-08-30 10:25:48

JavaScript進階操作前端

2023-06-27 16:42:18

Tinygrad深度學習工具

2013-06-20 10:28:39

MVVM框架avalon架構

2020-10-13 18:09:22

開發框架開源

2020-11-02 11:24:52

算法人臉識別技術

2011-03-02 10:03:44

SaturnJSJS

2022-02-12 21:05:11

異步爬蟲框架

2024-01-02 08:22:01

Koin框架項目

2022-07-15 16:39:19

PythonWhoosh工具

2010-07-07 09:30:41

WebMatrixWeb開發

2014-04-21 10:01:45

前后端分離

2025-01-03 09:17:26

JavaSpringBoot

2021-03-02 09:35:33

Python循環開發

2009-07-14 18:05:28

輕量級Swing組件
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久综合久久久 | 久久天天 | 99色综合| 午夜影院污 | 高清黄色毛片 | 国产精品91网站 | 一级片在线视频 | 国产三级大片 | 国产成人精品亚洲日本在线观看 | 一本大道久久a久久精二百 欧洲一区二区三区 | 二区三区在线观看 | 五月婷婷导航 | 久久国产精品视频免费看 | 黄色网毛片 | 久久久久久国产精品久久 | 成人在线精品视频 | 国产探花在线精品一区二区 | 日韩在线综合 | 亚洲高清视频一区二区 | 精品视频www| 亚洲区一区二区 | 国产中文字幕在线观看 | 成人精品国产 | 日本小电影网站 | 色视频在线播放 | 欧美一区二区三区精品 | 国产精品一区二区在线观看 | 在线观看中文字幕视频 | 日韩成人免费视频 | 男女网站免费 | 久久精品国产一区二区电影 | 精品久久久久一区二区国产 | 国产激情在线 | 久久久久国产 | 国产精品美女一区二区 | 黄网站在线观看 | 欧美男人天堂 | 国内精品视频在线 | 国产精品福利在线 | 亚洲色图网址 | 午夜影视在线观看 |