[TOC]html
咱們每學一個框架, 總會將他與其餘框架做比較程序員
Django web框架: 優勢 - 組件很是全,教科書框架,admin model-ORM session 缺點 - 資源浪費,由於組件多,大,仍是互相關聯的,隨便卸載組件,可能會形成項目的崩潰web
Flask web框架: 優勢 - 擴展性強,精簡小,簡單,第三方組件 session Flask-Session Flask-Admin 缺點 - 穩定性相對較差 ,第三方組件新版兼容性django
Tornado web框架: 優勢 - 異步IO,非阻塞,原生Websocket 缺點 - 所有手寫json
Sanic web框架: 優勢 - 與Flask本是同根生,異步框架,集合Flask與Tornado全部優勢 缺點 - 複雜度較高flask
pip install Flask
也能夠在Pycharm中選擇安裝~後端
啓動app.py下瀏覽器
from flask import Flask # 帶入Flask類 app = Flask(__name__) # 實例化Flask對象 app @app.route('/') # app中的路由裝飾器 def hello_world(): # 視圖函數 return 'Hello World!' if __name__ == '__main__': app.run(debug=True) # 啓動服務
瀏覽器訪問127.0.0.1:5000, 就會完成Flask的程序員儀式, 歡迎你成爲一個Flask用戶!!!cookie
1.return HttpResponse("輝哥真帥!")session
# 跟django中同樣, 直接返回字符串
2.return render_template("login.html")
# 返回一個html模板,相似django中 render @app.route('/login') def login(): return render_template('login.html')
3.return redirect("/")
# 與django中相同, 重定向
4.return send_file("美女.mp4")
# 打開並返回文件內容 自動識別文件類型 而且加入 Content-type:文件類型
5.return jsonify({"key": "value"})
# 返回標準格式的jsonz字符串, 在響應頭中加入Content-type:application
1.request.method
# 返回請求的方式, post,get...
2.request.form
# 返回Form表單中傳遞傳過來的值 print(request.form) # ImmutableMultiDict([('user', 'kong'), ('pwd', 'hui')]) # ImmutableMultiDict 它看起來像是的Dict 就用Dict的方法取值試一下吧 print(request.form["user"]) # kong print(request.form.get("pwd")) # hui # 看來所有才對了, ImmutableMultiDict 彷佛就是個字典,再來玩一玩它 print(list(request.form.keys())) # ['user', 'pwd'] 看來是又纔對了 #若是以上全部的方法你都以爲用的不爽的話 req_dict = dict(request.form) print(req_dict) # 若是你以爲用字典更爽的話,也能夠轉成字典操做(這裏有坑)
3.request.args
# 返回url中傳遞的參數
例如:
而後咱們看下:
print(request.args) # ImmutableMultiDict([('id', '1'), ('age', '20')]) print(request.args["id"]) # 1 print(request.args.get("age")) # 20 print(list(request.args.keys())) # ['id', 'age'] print(list(request.args.values())) # ['1', '20'] req_dict = dict(request.args) # {'id': ['1'], 'age': ['20']}
與 request.form的區別:
request.args 是獲取url中的參數
request.form 是獲取form表單中的參數
4.request.values
前段代碼:
看返回結果:
print(request.values) # CombinedMultiDict([ImmutableMultiDict([('id', '1'), ('age', '20')]), ImmutableMultiDict([('user', 'Oldboy'), ('pwd', 'DragonFire')])]) print(request.values.get("id")) # 1 print(request.values["user"]) # Oldboy # 這回喜歡直接操做字典的小夥伴們有驚喜了! to_dict() 方法能夠直接將咱們的參數所有轉爲字典形式 print(request.values.to_dict()) # {'user': 'Oldboy', 'pwd': 'DragonFire', 'id': '1', 'age': '20'}
可是有坑!!
# 若是url和form中的Key重名的話,form中的同名的key中value會被url中的value覆蓋 # http://127.0.0.1:5000/req?id=1&user=20 print(request.values.to_dict()) # {'user': 20 'pwd': 'DragonFire', 'id': '1'}
5.request.cookies
# 返回瀏覽器中的cookies信息
6.request.headres
# 返回請求頭中數據 print(type(request.headers)) """ Host: 127.0.0.1:5000 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2 Accept-Encoding: gzip, deflate Referer: http://127.0.0.1:5000/home Content-Type: application/x-www-form-urlencoded Content-Length: 26 Cookie: csrftoken=vDIozqveCEfArdYXlM6goHVlSQEn7h4bDygNphL2Feas60DiM2di0jlqKfxo7xhA Connection: keep-alive Upgrade-Insecure-Requests: 1 Cache-Control: max-age=0 """
7.request.data
# b"" 存放的是請求體中的原始信息 Content-Type:asdfkjashgjvajhgjkow
8.request.json
# 請求頭中存在 Content-Type:application/json 將請求體中的數據 存放在JSON中,沒有返回None
9.request.files
若是遇到文件上傳的話,request.files 裏面存的是你上傳的文件,可是 Flask 在這個文件的操做中加了必定的封裝,讓操做變得極爲簡單.
前段代碼: 後端:
print(request.files) # ImmutableMultiDict([('file', <FileStorage: 'DragonFire.txt' ('text/plain')>)]) print(request.files["file"]) # <FileStorage: 'DragonFire.txt' ('text/plain')> my_file = request.files["file"] my_file.save("OldBoyEDU.txt") # 保存文件,裏面能夠寫完整路徑+文件名
10.request獲取路徑
# 獲取當前的url路徑 print(request.path)# /req # 當前url路徑的上一級路徑 print(request.script_root) # # 當前url的所有路徑 print(request.url) # http://127.0.0.1:5000/req # 當前url的路徑的上一級所有路徑 print(request.url_root ) # http://127.0.0.1:5000/