中文在线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”)

?
最新亚洲AV电影网站| 久久天堂综合亚洲伊人HD妓女| 非洲黑人吊巨大VS亚洲女| 久久久橹橹橹久久久久高清| 女人被狂C躁到高潮视频| 亚洲AV成人无码久久精品老人| 国内老熟妇对白hdxxxx| 国产愉拍精品手机| 成年女人毛片免费观看97| 久久午夜夜伦鲁鲁片免费无码影视| 国产高清色高清在线观看| 五月丁香综合缴情六月小说| 亚洲精品国产高清在线观看| 亚洲尺码和欧洲尺码对照工具箱| 在线精品亚洲观看不卡欧| 天天摸夜夜添久久精品| 内射夜晚在线观看| 第一亚洲中文久久精品无码| 乱子伦一区二区三区| 亚洲色无码国产精品网站可下载| 又色又爽又黄又无遮挡网站| 欧洲成人4卡5卡6卡7卡| a级无遮挡超级高清-在线观看| 久久精品无码一区二区APP| 国产精品无码午夜福利| 可以在线看AV的网站| 免费少妇a级毛片| 亚洲成AV人最新地堂无码| 国产成人无码精品一区不卡| 亚洲国产精品隔壁老王| 欧美人妻一区二区三区| 亚洲高清最新AV网站| 在线观看的资源视频| 特级做A爰片毛片免费看108| 亚洲欧美日韩中文字幕在线一区| 国产精品无码免费专区午夜| 亚洲国产精品无码久久电影| 成人精品综合免费视频| 久久国产乱子伦精品免费午夜| 亚洲女同精品一区二区| 国产精品久久国产精麻豆99网站|