亚洲国产av一区二区三区-久久精品人妻无码一区二区三区v-无码国产精品高清免费-国产成+人+综合+欧美亚洲-国产精品55夜色66夜色

網站開發 APP開發 小程序開發 SEO優化 公司新聞

基于flask的微信開發(1flask基礎)

2018-05-22 09:34:09
1733

  基于flask的微信開發

  公眾號進行簡單的開發,使用的是webpy這個框架,確實輕巧,也容易上手,但是后來了解到作者已經自殺,框架也沒有人在維護了,所以就放棄了。不過還是致敬作者。這次打算把原先開發的內容遷移到flask上,據說也是比較輕巧,且擴展性非常好,所以有了這個文章,讓我們一起來走進flask的世界。

  flask的安裝

  pip install flask

  但是我們建議是在虛擬環境下去安裝,這樣子才不會污染全局的環境,造成一些不必要的錯誤。

  最小的應用

  額外說一些,其實flask用來構建web應用,web應用是基于http協議的。換句話說,我們可以這樣子認為,我們創建頁面,通過http協議進行網絡之間的傳輸,實現信息的共享。

  測試代碼:

  from flask import Flask

  app=Flask(__name__)

  @app.route("/")

  def index():

  return "hello,world"

  if __name__=="__main__":

  app.run()

  解析:

  可以將Flask看成是我們開發的程序,@app.route設置路由,所謂的路由就是將某個url路徑映射到哪一段代碼上。像上邊,我們將/映射到index函數上,這個模式和.net非常的相似。其實index函數是幫助我們生成和定制http協議中的回包的,這樣理解更好一些。

  app.run讓我們的代碼跑在本地的服務器上,是flask內置的服務器。

  調試模式:

  我們可以在啟動的時候指定服務器為調試模式,調試模式下,當我們修改代碼后,服務器會自定的重新進行加載。

  設置的方式:

  app.run(debug=True) or app.debug=True app.run()

  路由

  路由的設置是通過裝飾器來實現的,裝飾器可以實現橫向切入,即在運行這個函數的時候,可以先運行其他的代碼。像.net里面的注解。

  在路由里面指定變量規則

  給url添加變量的規則是<變量類型:變量名>

  變量類型有:int float path(輸入的部分是路徑)

  測試代碼:

  @app.route("/hello/<username>")

  def hello(username):

  return "hello %s" % username

  @app.route("/hello1/<int:c>")

  def count(c):

  return "you entered %d" % c

  @app.route("/hello2/<path:p>")

  def hello2(p):

  return "the path is %s" % p

  生成url

  url_for函數生成url

  這個函數的第一個參數是一個函數的名字,第二個可以傳遞參數

  設置http方法

  通過設置app.route()這個函數的methods參數,我們可以讓函數支持相應的http方法,methods參數是一個list,我們可以傳相應的方法進去

  測試代碼

  @app.route("/testzz",methods=["GET","POST"])

  def testzz():

  if request.method=="GET":

  return "the get"

  elif request.method=="POST":

  return "the post"

  else:

  pass

  靜態文件的支持

  我們會在網頁中引用一些css或者是一些圖片之類的東西。

  這里使用慣例,我們可以將靜態的內容放在static目錄下,并且路由系統已經為我們做好了這個映射,我們可以使用static/文件名來訪問

  模板渲染

  我們使用Python來生成html是一件很苦逼的事情,很繁瑣,也很麻煩,所以我們這里使用模板引擎來生成前端的HTML頁面。flask中配備了jinjia2模板引擎。

  測試代碼:

  @app.route("/testtemplate")

  @app.route("/testtemplate/<username>")

  def testtemplate(username=None):

  return render_template("test.html",username=username)

  <!doctype html>

  <html>

  <title>hello from flask</title>

  {% if username %}

  hello {{username}}

  {% else %}

  hello,world

  {% endif %}

  </html>

  訪問請求數據

  獲取請求數據,我們通過請求對象request

  獲取GET提交的數據 request.args.get()

  獲取POST或者PUT提交的數據 request.form[“”]

  代碼測試:

  def login():

  if request.method=="GET":

  username=request.args.get("username")

  passwd=request.args.get("passwd")

  return render_template("login.html",m="GET METHOD",username=username,passwd=passwd)

  elif request.method=="POST":

  username=request.form["username"]

  passwd=request.form["passwd"]

  return render_template("login.html",m="POST METHOD",username=username,passwd=passwd)

  else:

  return "error"

  文件上傳

  上傳到服務器端的文件,我們可以通過request.files這個對象來獲取

  測試代碼:

  @app.route("/upload",methods=["GET","POST"])

  def upload():

  if request.method=="POST":

  f=request.files["test"]

  f.save(werkzeug.secure_filename(f.filename))

  return "ok"

  elif request.method=="GET":

  return render_template("upload.html")

  else:

  return "error"

  notice:

  secure_filename這個函數可以為程序提供安全性,保存前確保使用這個函數,這個函數在werkseug這個庫里面

  cookie解析

  cookie是用來跟蹤用戶的。flask中訪問和設置cookie可以通過cookies和set_cookie來實現。

  設置cookie

  通常我們在在視圖函數中返回一個視圖,其實也是相當于返回一個字符串的,只不過這個字符串的內容是html內容,flask幫助我們封裝了response的包,我們可以自己來定制這個response,通過flask中的make_response這個函數。設置cookie是需要設置響應體的,所以需要我們定制response。

  設置cookie

  測試代碼

  @app.route("/setcookie")

  def setCookie():

  resp=make_response()

  resp.set_cookie("username","zhanggd")

  return resp

  獲取cookie

  從客戶端接受到的請求包的內容會被flask封裝進request這個對象內,我們通過這個對象來獲取cookie

  測試代碼

  @app.route("/getcookie")

  def getCookie():

  c=request.cookies["username"]

  return c

  重定向和錯誤

  重定向

  當訪問一個url的時候,跳轉到另一個url對應的位置。

  整個過程為:

  當請求這個url的時候,返回一個code為302的包,然后瀏覽器會訪問302中location中指定的url

  測試代碼:

  @app.route("/")

  def index():

  return redirect(url_for("test"))

  錯誤

  當瀏覽器訪問非法的頁面,或者是提交了非法的內容,我們將要返回給他錯誤的頁面。

  返回一個401

  測試代碼

  @app.route("/test2")

  def test3():

  abort(401)

  自定義404頁面(同樣通過abort進行跳轉)

  @app.errorhandler(404)

  def page_not_found(error):

  return render_template("404.html"),404

  關于響應

  我們在視圖函數里面可以返回三種類型的值:

  字符串:如果返回的是字符串,flask直接封裝進回包的體內

  元祖:如果是元祖的話,flask會根據你設置的相應內容來設置相應的回包,元祖的格式為(視圖,status,headers)headers可以是list或者是字典

  響應對象:如果是直接響應對象,直接根據這個對象來構造

  操作回包代碼測試:

  @app.route("/test3")

  def test4():

  resp=make_response(render_template("404.html"),404)

  resp.headers["test"]="test"

  return resp

  會話

  允許在不同請求之間存儲用戶的信息。

  flask中使用session,這個是session是基于cookie的

  我們需要設置一個秘鑰:app.secret_key=””

  session為一個字典,設置值session[“username”]=username

  刪除session中的值,session.pop(“username”)

?
主站蜘蛛池模板: 99精品视频在线观看免费| 中文字幕久久波多野结衣av不卡| 99久久国产综合精品女图图等你 | 国产成人亚洲综合无码8| 奇米影视888欧美在线观看| 亚洲精品欧美精品日韩精品| 亚洲人成日韩中文字幕不卡| 66亚洲一卡2卡新区成片发布| 亚洲色欲av无码成人专区| 丁香婷婷无码不卡在线| 国产精品自产拍在线观看免费| 久久精品人人爽人人爽| 亚洲精品欧美日韩一区| 欧美精欧美乱码一二三四区| 久久精品人人做人人爽| 欧美颜射内射中出口爆在线| 国产偷人激情视频在线观看| 亚洲中文字幕久久精品无码a| 国产三级在线观看播放视频| 国产亚洲精品久久无码98| 国产成人久久综合一区| 亚洲欧美一区二区三区在线| 老熟女高潮一区二区三区| 色香欲天天天影视综合网| 欧美人与动牲交a免费观看 | 亚洲处破女av日韩精品| 亚洲国产av久久久| av片亚洲国产男人的天堂| 国产超碰女人任你爽| 午夜男女爽爽影院免费视频下载| 久久精品国产99国产精2021| 色悠久久久久久久综合网| 欧美综合天天夜夜久久| 久久久精品久久久久久96| 国色天香国产精品| 国产精品禁18久久久夂久| 日本另类αv欧美另类aⅴ| 国产乱码人妻一区二区三区| 日本在线 | 中文| 国产乱妇无码大片在线观看| 国产真人性做爰久久网站 |