flask的路由配置,特殊装饰器
1,flask中的路由
- endpoint-url_for反向地址
- endpoint默认是视图函数名endpoint="雪雪"
- methods 指定视图函数的请求方式,默认GET
- default={"nid":1}指定视图函数的默认值
- strict_slashes = False 是否严格遵循路由规则/login/
- redirect_to"/xueren/" 永久跳转地址301
- 动态路由参数
- /<int:nid> / <string:str> / <nid>
- 视图函数中需要有参数接收动态参数
2,Flask中的实例化配置
- template_folder = "temp" # template模板目录,默认当前项目中的template目录
- static_folder = "xuexue"目录
- static_url_path= "/static" # 访问路径
- host_matching = False # 如果不是特别需要,慎用,否则所欲的route都需要host=""参数
- subdomain_matching = False # 理论上来说是用来限制SERVER_NAME子域名,
- instance_path = None. # 指向另一个Flask实例的路径
- instance_relative_config = Flase # 是否加载另一个实例的配置
- root_path = None # 主模块所在的目录绝对路径,默认项目目录
3,app对象配置
- app.config.from_object(Debug)
- class Debug(object):
- DEBUG = true
4,Blueprint
- from flask import Blueprint
- blue = Blueprint("blue_id", __name__,url_prefix="user"每次访问蓝图的路径前缀)
- app.reguster_blueprint(blue)
5,特殊装饰器:
- @app.template_global()
- @app.template_filter()
- @app.before_request # 请求进入视图函数之前
- @app.after_request
- def af1(response)
- return response # 结束视图函数之后, 返回客户端之前
- 正常:be1---be2---be3---af3---af2---af1
- 异常:be1---af3---af2---af1
- @app.errorhandler(404)重定义页面
- def error404(args):
- return args
- 基于蓝图实现增删改查数据,基于Before_request session实现用户校验,可选errorhandler
具体代码如下:
蓝图代码:
from flask import Flask, request, render_template, redirect, session
from serv import users
import weishenme
app = Flask(__name__, static_url_path="/static") # 注册配置类
app.config.from_object(weishenme.Debug) # 注册蓝图
app.register_blueprint(users.user_blue) @app.route("/detail")
def detail():
return render_template("detail.html") @app.route("/login", methods=["GET", "POST"])
def login():
if request.method == "GET":
return render_template("login1.html")
else:
session["user"] = request.form.get("user")
return redirect("/") @app.route("/")
def xiaocai():
return "骚帆是一根小菜" if __name__ == '__main__':
app.run(debug=True)
配置类:
class Debug(object):
DEBUG=True
SECRET_KEY="xuexue"
SESSION_COOKIE_NAME="xiaoxue" class Testing(object):
TESTING=True
SECRET_KEY="xiaopangpang"
SESSION_COOKIE_NAME="xueer" class Production(object):
SECRET_KEY="xueren"
SESSION_COOKIE_NAME="csrf_token"
app的代码:
from flask import Flask, session, redirect, url_for, render_template, request
import weishenme
# 实例化一个Flask对象app
app = Flask(__name__) # __name__表示是当前目录
# 指定session的key是xuexue
app.secret_key = "xuexue" # 注册配置类
# app.config.from_object(weishenme.Debug)
app.config.from_object(weishenme.Testing) # 装饰器
def outer(func):
def hahaha(*args, **kwargs):
if session["user"]:
print(session["user"])
ret = func(*args, **kwargs)
return ret
else:
return redirect("/login")
return hahaha @app.route("/<nid>", endpoint="wc", methods=["GET", "POST"])
@outer
def wc(nid):
print(nid)
return render_template("xuexue.html") @app.route("/detail", endpoint="detail")
@outer
def detail():
print("detail")
return render_template("detail.html") @app.route("/login", methods=["GET", "POST"], strict_slashes=False)
def login():
if request.method == "GET":
return render_template("login1.html")
else:
session["user"] = request.form.to_dict().get("user")
return redirect("/miss") if __name__ == '__main__': # 运行这个flask项目
app.run(host="0.0.0.0", port=2018)
请求执行流程代码:
from flask import Flask, request, session, render_template, redirect, session
import weishenme
from serv import users app = Flask(__name__, static_folder="static_list", static_url_path="/static")
# 到瑞配置类
app.config.from_object(weishenme.Debug)
# 注册蓝图
app.register_blueprint(users.user_blue) @app.before_request
def is_login():
print("b1")
if request.path == "/login" :
return None
elif session.get("user"):
return None
else:
return redirect("/login") @app.before_request
def b2():
print("b2")
return None @app.before_request
def b3():
print("b3")
return None @app.after_request
def af1(res):
print("af1")
return res @app.after_request
def af2(res):
print("af2")
return res @app.after_request
def af3(res):
print("af3")
return res @app.route("/", endpoint="index",methods=["POST", "GET"])
def index():
return render_template("index1.html") @app.route("/detail", endpoint="detail")
def detail():
return render_template("detail.html") @app.route("/login", methods=["GET", "POST"], strict_slashes=False)
def login():
if request.method == "GET":
return render_template("login1.html")
else:
print("xiaoxue")
session["user"] = request.form.get("user")
return redirect("/") @app.errorhandler(404)
def error(args):
print(args)
return "您访问的页面不存在,或者走丢了.....%s" % args if __name__ == '__main__':
app.run(debug=True)
flask的路由配置,特殊装饰器的更多相关文章
- flask 第三章 特殊装饰器 CBV Flask-Session WTForms
1.flask中的特殊装饰器 前面我们讲过的装饰器函数中,用来登录验证,这次我们来介绍几个flask中的特殊装饰器 1). @app.before_request 具体的用途是: 在请求进入视图函数之 ...
- Flask蓝图Blueprint和特殊装饰器
Flask 中的 蓝图 Blueprint 不能被run的flask实例:相当于django中的app01 应用 蓝图作用:功能隔离 路由隔离 Blueprint就是 一个不能run的flask 蓝图 ...
- Django drf:视图层封装、ViewSetMixin、路由配置、解析器、响应器
一.视图层封装 二.ViewSetMixin 三.路由配置 四.解析器 五.响应器 一.视图层封装 1.基本视图 写一个出版社的增删改查resfull接口 路由: url(r'^publish/$', ...
- Flask中那些特殊的装饰器
模板相关的装饰器 @app.template_global() 用法: @app.template_global() # 记得加括号 def jiafa(a, b): # 这个方法每调用一次就需要传一 ...
- flask+blueprint路由配置
1.flask默认的静态文件和html文件在app应用文件夹里的相应文件夹下:app // Flask||--static ||--templates |静态文件默认的url地址为:url_prefi ...
- tornado 第二种路由方法(装饰器)
#!/usr/bin/env python # _*_coding:utf-8 _*_ import tornado.ioloop import tornado.web application = t ...
- Flask需要登录权限的装饰器写法
def wapper(func): def inner(*args,**kwargs): if not request.cookies.get("username"): retur ...
- python装饰器 语法糖
简介: 装饰器(Decorators)是 Python 的一个重要部分.简单地说:他们是修改其他函数的功能的函数. 比如说我们写flask,路由就是用装饰器定义的.如果写权限控制,那么权限控制一般也是 ...
- Flask之基于route装饰器的路由系统(源码阅读解析)
一 路由系统 1. 在flask中配置URL和视图函数的路由时,首先需要在main.py中实例化一个app对象: from flask import Flask, render_template ap ...
随机推荐
- svn服务
svn服务实战应用指南 1.1 svn介绍 什么是svn? svn(sub-version)是近年来崛起的非常优秀的版本管理工具,与cvs管理工具一样,svn是一个跨平台的开源的版本控制系统, ...
- (十七)python 3 函数递归
递归函数 即自己调用自己,递归中可以函数自身调用自身,但是使用时类似于条件循环一样,要有递归的终止条件 优点:使用递归时,常常可以让代码更加简洁 缺点:递归会占用比较多的内存,当递归次数比较多时,性能 ...
- 爬虫app信息抓取之apk反编译抓取
之前也抓过一些app,数据都比较好取,也没有研究的太深,毕竟还有android 模拟器+ appium 的方法.直到遇见了一款app ,具体名字就不说了,它安装在模拟器上竟然打不开 !!第一次遇见上网 ...
- luoguT21778 过年
差分一下上线段树 #include <iostream> #include <cstdio> #include <vector> using namespace s ...
- 【MVC 2】MVC+EF框架结构实例:注册ID号验证
导读:本篇博客,将通过一个实例,详细介绍MVC+EF的应用.原理性的东西或者说是进一步的解耦和,请看博客: [框架结构 3]MVC+EF实体框架-原理解析.在这里,仅用MVC框架和一个EF生成的Mod ...
- POJ3246-Balanced Lineup,好经典的题,做法和HDU-I hate it 一样~~
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Case Time Limit: 2000MS Description For ...
- PTA 04-树5 Root of AVL Tree (25分)
题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/668 5-6 Root of AVL Tree (25分) An AVL tree ...
- 【随机化算法】codeforces Matrix God
http://codeforces.com/gym/101341 [题意] 给定三个方阵A,B,C,问AB=C是否成立? 方阵的规模最大为1000 [思路] 求AB的时间复杂度为n*n*n,会超时 左 ...
- 《TCP/IP详解卷1:协议》——第5章 RARP:逆地址解析协议(转载)
1.引言 具有本地磁盘的系统引导时,一般是从磁盘上的配置文件中读取IP地址.但是无盘机,如X终端或无盘工作站,则需要采用其他方法来获得IP地址. 网络上的每个系统都具有唯一的硬件地址,它是由网络接口生 ...
- Linux内核设计与实现——读书笔记1:内核简介
内核:有的时候被称管理者或者操作系统核心,通常内核负责响应中断的中断服务程序, 负责管理多个进程从而分享处理器时间的调度程序,负责管理进程地址空间德内存管理程序 和网络,进程间通信等系统服务程序共同组 ...