亚洲国产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”)

?
主站蜘蛛池模板: 亚洲女教师丝祙在线播放| 亚洲色大成网站www看下面| 成在线人免费视频播放| 麻麻张开腿让我爽了一夜| 国产mv在线天堂mv免费观看| 在线视+欧美+亚洲日本| 亚洲国产精品久久久久婷婷老年| 日韩内射激情视频在线播放免费 | 看全黄大色黄大片美女| 色综合久久网| 日韩欧美偷拍高跟鞋精品一区| 日日摸天天摸人人看| 亚洲蜜桃精久久久久久久久久久久| 中文字幕av无码免费久久| 日产精品久久久久久久| 亚洲成在人线a免费77777| 97久久精品人人做人人爽| 日韩人妻无码精品专区| 亚欧乱色熟女一区二区| 夜夜躁狠狠躁日日躁视频| 久久国产亚洲精选av| 色综合久久中文综合网| 在线观看无码av网站永久| 精品国精品自拍自在线| 精品精品国产欧美在线小说区| 国产精品国产三级国产av剧情| 中国杭州少妇xxxx做受| 日本亚欧热亚洲乱色视频| 精品国产乱码久久久久久口爆 | 少妇人妻系列无码专区视频| 亚洲精品中文幕一区二区| 久久综合狠狠综合久久| 国产熟妇高潮呻吟喷水| 少妇高潮毛片色欲ava片| 无码人妻精品一区二区蜜桃网站 | 极品av麻豆国产在线观看| 无遮挡啪啪摇乳动态图| 97人妻精品一区二区三区| 99久久亚洲精品无码毛片| 久久99精品久久只有精品| 亚洲欧美va在线播放|