python中Webflask視圖內(nèi)容和模板怎么實現(xiàn)-創(chuàng)新互聯(lián)

這篇文章主要為大家展示了“python中Web flask視圖內(nèi)容和模板怎么實現(xiàn)”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“python中Web flask視圖內(nèi)容和模板怎么實現(xiàn)”這篇文章吧。

公司專注于為企業(yè)提供成都做網(wǎng)站、網(wǎng)站建設、外貿(mào)營銷網(wǎng)站建設、微信公眾號開發(fā)、成都做商城網(wǎng)站,重慶小程序開發(fā),軟件定制網(wǎng)站建設等一站式互聯(lián)網(wǎng)企業(yè)服務。憑借多年豐富的經(jīng)驗,我們會仔細了解各客戶的需求而做出多方面的分析、設計、整合,為客戶設計出具風格及創(chuàng)意性的商業(yè)解決方案,成都創(chuàng)新互聯(lián)公司更提供一系列網(wǎng)站制作和網(wǎng)站推廣的服務。

基本使用

#
設置cookie值@ app.route('/set_cookie')
def set_cookie(): response = make_response("set_cookie")
response.set_cookie("name", "zhangsan")
response.set_cookie("age", "13", 10) #10秒有效期

 return response

# 獲取cookie@ app.route('/get_cookie')
def get_cookie(): #獲取cookie, 可以根據(jù)cookie的內(nèi)容來推薦商品信息# name = request.cookies['haha']
name = request.cookies.get('name')
age = request.cookies.get('age')
return "獲取cookie,name is %s, age is %s" % (name, age)# 設置SECRET_KEY
app.config["SECRET_KEY"] = "fhdk^fk#djefkj&*&*&"#
設置session@ app.route('/set_session/<path:name>')
def set_session(name): session["name"] = name
session["age"] = "13"
return "set session"#
獲取session內(nèi)容@ app.route('/get_session')
def get_session(): name = session.get('name')
age = session.get('age')
return "name is %s, age is %s" % (name, age)

session的存儲依賴于cookie,在cookie保存的session編號

session編號生成,需要進行加密,所以需要設置secret_key secret_key的作用參考:

https://segmentfault.com/q/1010000007295395

上下文:保存的一些配置信息,比如程序名、數(shù)據(jù)庫連接、應用信息等

相當于一個容器,保存了 Flask 程序運行過程中的一些信息。

Flask中有兩種:請求上下文(session,cookie),應用上下文(current_app,g)

current_app,g是全局變量:

current_app.test_value='value'

g.name='abc' # g是一個響應里的全局變量可跨文件

渲染模板:

from flask
import Flask, render_template
app = Flask(__name__)# 默認省略了三個參數(shù), static_url_path, static_folder, template_folders
def adds(a, b): return a + b@ app.route('/')
def hello_world(): #定義數(shù)據(jù), 整數(shù), 字符串, 元祖, 列表, 字典, 函數(shù)
num = 10
str = "hello"
tuple = (1, 2, 3, 4)
list = [5, 6, 7, 8]
dict = {
 "name": "張三",
 "age": 13
}
return render_template('file01.html', my_num = num, my_str = str, my_tuple = tuple, my_list = list, my_dict = dict, adds = adds)《 html》 {
 {}
}, {
 {
  dict[‘name']
 }
}, {
 {
  dict.get(‘name')
 }
}
和 { % %
}, {
 {
  adds(1, 2)
 }
}#
模板全局--直接使用@ app.template_global('adds')
def adds(a, b): return a + b

過濾器&自定義過濾器

{{ 字符串 | 字符串過濾器 }}
Safe,lower,upper,little,reverse,format
{#防止轉(zhuǎn)義#}
{{ str1 | safe}} 或 在方法里str2 = Markup("<b>只有學習才能讓我快樂</b>")
{{ 列表 | 列表過濾器 }}
First,last,length,sum,sort
def do_listreverse(li):
 #通過原列表創(chuàng)建一個新列表
temp_li = list(li)
# 將新列表進行返轉(zhuǎn)
temp_li.reverse()
return temp_li
app.add_template_filter(do_listreverse, 'lireverse')# 或1
@ app.template_filter('lireverse')# 或2
def do_listreverse(li):
 #通過原列表創(chuàng)建一個新列表
temp_li = list(li)
# 將新列表進行返轉(zhuǎn)
temp_li.reverse()
return temp_li
<h3>my_array 原內(nèi)容:{{ my_array }}</h3>
<h3> my_array 反轉(zhuǎn):{{ my_array | lireverse }}</h3>

宏、繼承、包含

宏
{% macro input(name,value='',type='text') %}
 <input type="{{type}}" name="{{name}}" value="{{value}}">
{% endmacro %}
{{ input('name',value='zs')}} // 調(diào)用
繼承
父模板base:
{% block top %}
 頂部菜單
{% endblock top %}
子模板:
{% extends 'base.html' %}
{% block content %}
 需要填充的內(nèi)容
{% endblock content %}
包含
{% include 'hello.html' %}
Flask 的模板中特有變量和方法
{{config.DEBUG}}
輸出:True
{{request.url}}
輸出:http://127.0.0.1
{{ g.name }}
{{url_for('home')}} // url_for 會根據(jù)傳入的路由器函數(shù)名,返回該路由對應的URL
{{ url_for('post', post_id=1)}}
這個函數(shù)會返回之前在flask中通過flask()傳入的消息的列表,flash函數(shù)的作用很簡單,可以把由Python字符串表示的消息加入一個消息隊列中,再使用get_flashed_message()函數(shù)取出它們并消費掉
{%for message in get_flashed_messages()%}
 {{message}}
{%endfor%}
模板規(guī)則:
<form action="{{ url_for('login') }}" method="post">
<link rel="stylesheet" href="{{ url_for('static',filename='css.css') }}" rel="external nofollow" >

web表單

if request.method == 'POST':
  # post請求的數(shù)據(jù)
  print(request.form.get('uname'))
  print(request.form.get('upass'))
  # 存session
  return redirect("/")
# get請求的數(shù)據(jù)
 print(request.args.get('uname'))
 print(request.args.get('upass'))
 # post請求的數(shù)據(jù)
 print(request.form.get('uname'))
 print(request.form.get('upass'))

CSRF

from flask_wtf import CSRFProtect
#設置SECRET_KEY
app.config["SECRET_KEY"] = "fjkdjfkdfjdk"
#保護應用程序
CSRFProtect(app)
{#設置隱藏的csrf_token,使用了CSRFProtect保護app之后,即可使用csrf_token()方法#}
 <input type="hidden" name="csrf_token" value="{{ csrf_token() }}">

以上是“python中Web flask視圖內(nèi)容和模板怎么實現(xiàn)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設計公司行業(yè)資訊頻道!

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

本文題目:python中Webflask視圖內(nèi)容和模板怎么實現(xiàn)-創(chuàng)新互聯(lián)
本文URL:http://muchs.cn/article2/ijpic.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、外貿(mào)網(wǎng)站建設網(wǎng)站排名、網(wǎng)站維護、動態(tài)網(wǎng)站商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設