中文在线8资源库,亚洲国产一区二区三区在线观看,日日噜噜夜夜狠狠久久无码区,天天综合网天天综合色

網(wǎng)站開發(fā) APP開發(fā) 小程序開發(fā) SEO優(yōu)化 公司新聞

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

2018-05-22 09:34:09
1360

  基于flask的微信開發(fā)

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

  flask的安裝

  pip install flask

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

  最小的應用

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

  測試代碼:

  from flask import Flask

  app=Flask(__name__)

  @app.route("/")

  def index():

  return "hello,world"

  if __name__=="__main__":

  app.run()

  解析:

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

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

  調試模式:

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

  設置的方式:

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

  路由

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

  在路由里面指定變量規(guī)則

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

  變量類型有: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函數(shù)生成url

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

  設置http方法

  通過設置app.route()這個函數(shù)的methods參數(shù),我們可以讓函數(shù)支持相應的http方法,methods參數(shù)是一個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

  靜態(tài)文件的支持

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

  這里使用慣例,我們可以將靜態(tài)的內容放在static目錄下,并且路由系統(tǒng)已經(jīng)為我們做好了這個映射,我們可以使用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>

  訪問請求數(shù)據(jù)

  獲取請求數(shù)據(jù),我們通過請求對象request

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

  獲取POST或者PUT提交的數(shù)據(jù) 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這個函數(shù)可以為程序提供安全性,保存前確保使用這個函數(shù),這個函數(shù)在werkseug這個庫里面

  cookie解析

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

  設置cookie

  通常我們在在視圖函數(shù)中返回一個視圖,其實也是相當于返回一個字符串的,只不過這個字符串的內容是html內容,flask幫助我們封裝了response的包,我們可以自己來定制這個response,通過flask中的make_response這個函數(shù)。設置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中l(wèi)ocation中指定的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

  關于響應

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

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

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

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

  操作回包代碼測試:

  @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精品| 全免费又大粗又黄又爽少妇片| 欧美粗大无套gay| 亚洲中文久久精品无码浏不卡| 狠狠色噜噜狠狠狠狠米奇777| 亚洲AV无码一区东京热久久| 99久久精品午夜一区二区| 女人张开腿让男人桶爽的| 无码中出人妻中文字幕AV| 柠檬福利第一导航在线| 日韩精品无码一本二本三本| 久久精品成人欧美大片| 免费国产大片APP软件推荐| 久久精品女人天堂av| 超碰最新上传| 亚洲中文字幕不卡无码| 久久久无码精品一区二区三区蜜桃| 国产精品久久久久永久免费看| 久久国产免费直播| 国产情侣激情在线对白| 日本乱偷互换人妻中文字幕| 国内精品伊人久久久影视| 日本三级韩国三级人妻| 成人区精品一区二区不卡AV免费| 久久国产精品香蕉成人APP| 久久综合伊人77777| 性虎精品无码AV导航| 日韩一区二区不卡黄色伦理电影| 国产精品无码一区二区三区不卡| 亚1州区2区3区产品乱码站| 高清破外女出血av毛片| 亚洲AV成人无码一区在线观看| 国产AV天堂一区二区三区| 一本一道久久综合狠狠老| 玩两个丰满老熟女久久网| 宅男噜噜噜66在线观看| 张柏芝用嘴给陈冠希高潮| 人人妻人人澡人人爽人人精品蜜桃| 免费看国产精品3A黄的视频| 国产乱人伦偷精品视频免观看| 国产av影片麻豆精品传媒|