最爽无遮挡行房视频-一本大道久久东京热无码av-中文字幕av一区-高中生自慰www网站-色婷婷久久综合中文久久蜜桃av

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

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

2018-05-22 09:34:09
1734

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

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

  flask的安裝

  pip install flask

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

  最小的應(yīng)用

  額外說一些,其實flask用來構(gòu)建web應(yīng)用,web應(yīng)用是基于http協(xié)議的。換句話說,我們可以這樣子認為,我們創(chuàng)建頁面,通過http協(xié)議進行網(wǎng)絡(luò)之間的傳輸,實現(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設(shè)置路由,所謂的路由就是將某個url路徑映射到哪一段代碼上。像上邊,我們將/映射到index函數(shù)上,這個模式和.net非常的相似。其實index函數(shù)是幫助我們生成和定制http協(xié)議中的回包的,這樣理解更好一些。

  app.run讓我們的代碼跑在本地的服務(wù)器上,是flask內(nèi)置的服務(wù)器。

  調(diào)試模式:

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

  設(shè)置的方式:

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

  路由

  路由的設(shè)置是通過裝飾器來實現(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ù)

  設(shè)置http方法

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

  測試代碼

  @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)的內(nè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"

  文件上傳

  上傳到服務(wù)器端的文件,我們可以通過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中訪問和設(shè)置cookie可以通過cookies和set_cookie來實現(xiàn)。

  設(shè)置cookie

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

  設(shè)置cookie

  測試代碼

  @app.route("/setcookie")

  def setCookie():

  resp=make_response()

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

  return resp

  獲取cookie

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

  測試代碼

  @app.route("/getcookie")

  def getCookie():

  c=request.cookies["username"]

  return c

  重定向和錯誤

  重定向

  當訪問一個url的時候,跳轉(zhuǎn)到另一個url對應(yīng)的位置。

  整個過程為:

  當請求這個url的時候,返回一個code為302的包,然后瀏覽器會訪問302中l(wèi)ocation中指定的url

  測試代碼:

  @app.route("/")

  def index():

  return redirect(url_for("test"))

  錯誤

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

  返回一個401

  測試代碼

  @app.route("/test2")

  def test3():

  abort(401)

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

  @app.errorhandler(404)

  def page_not_found(error):

  return render_template("404.html"),404

  關(guān)于響應(yīng)

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

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

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

  響應(yīng)對象:如果是直接響應(yīng)對象,直接根據(jù)這個對象來構(gòu)造

  操作回包代碼測試:

  @app.route("/test3")

  def test4():

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

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

  return resp

  會話

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

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

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

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

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

?
主站蜘蛛池模板: 色拍拍在线精品视频| 国产一区二区三区在线观看免费| 无码人妻av免费一区二区三区 | 亚洲国内精品自在线影院| 蜜桃视频在线观看免费视频网站www| 色88久久久久高潮综合影院| 中文字幕无码乱人伦在线| 人妻少妇精品一区二区三区| 国产精品夜色一区二区三区| 精品无码一区二区三区电影| 97午夜理论片影院在线播放| 国内精品久久久久影院免费| 色综合天天综合狠狠爱_| 国产午夜福利短视频| 性一交一乱一伧国产女士spa| 99国产精品自在自在久久| 欧美一区二区三区视频在线观看| 波多野结衣 黑人| 国产成人精品亚洲日本在线观看| 国产精品色情国产三级在| 国产成人a∨麻豆精品| 久久人妻国产精品| 久热在线播放中文字幕| 国产精品久久一区二区三区| 国产精品一区二区在线观看| 久久99成人免费| 国产国语亲子伦亲子| 开心五月综合亚洲| 天堂资源在线www中文| 久久伊人色av天堂九九小黄鸭| 毛茸茸厕所偷窥xxxx| 亚洲无人区码suv| 337p日本欧洲亚洲大胆裸体艺术| 毛茸茸厕所偷窥xxxx| 97国产精华最好的产品亚洲| 亚洲中文字幕久久精品无码va| 亚洲高清专区日韩精品| 国产大片内射1区2区| 国产网友自拍在线视频| 亚洲欧美一区二区成人片| 加勒比无码一区二区三区|