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的路由配置,特殊装饰器的更多相关文章

  1. flask 第三章 特殊装饰器 CBV Flask-Session WTForms

    1.flask中的特殊装饰器 前面我们讲过的装饰器函数中,用来登录验证,这次我们来介绍几个flask中的特殊装饰器 1). @app.before_request 具体的用途是: 在请求进入视图函数之 ...

  2. Flask蓝图Blueprint和特殊装饰器

    Flask 中的 蓝图 Blueprint 不能被run的flask实例:相当于django中的app01 应用 蓝图作用:功能隔离 路由隔离 Blueprint就是 一个不能run的flask 蓝图 ...

  3. Django drf:视图层封装、ViewSetMixin、路由配置、解析器、响应器

    一.视图层封装 二.ViewSetMixin 三.路由配置 四.解析器 五.响应器 一.视图层封装 1.基本视图 写一个出版社的增删改查resfull接口 路由: url(r'^publish/$', ...

  4. Flask中那些特殊的装饰器

    模板相关的装饰器 @app.template_global() 用法: @app.template_global() # 记得加括号 def jiafa(a, b): # 这个方法每调用一次就需要传一 ...

  5. flask+blueprint路由配置

    1.flask默认的静态文件和html文件在app应用文件夹里的相应文件夹下:app // Flask||--static ||--templates |静态文件默认的url地址为:url_prefi ...

  6. tornado 第二种路由方法(装饰器)

    #!/usr/bin/env python # _*_coding:utf-8 _*_ import tornado.ioloop import tornado.web application = t ...

  7. Flask需要登录权限的装饰器写法

    def wapper(func): def inner(*args,**kwargs): if not request.cookies.get("username"): retur ...

  8. python装饰器 语法糖

    简介: 装饰器(Decorators)是 Python 的一个重要部分.简单地说:他们是修改其他函数的功能的函数. 比如说我们写flask,路由就是用装饰器定义的.如果写权限控制,那么权限控制一般也是 ...

  9. Flask之基于route装饰器的路由系统(源码阅读解析)

    一 路由系统 1. 在flask中配置URL和视图函数的路由时,首先需要在main.py中实例化一个app对象: from flask import Flask, render_template ap ...

随机推荐

  1. svn服务

    svn服务实战应用指南 1.1     svn介绍 什么是svn? svn(sub-version)是近年来崛起的非常优秀的版本管理工具,与cvs管理工具一样,svn是一个跨平台的开源的版本控制系统, ...

  2. (十七)python 3 函数递归

    递归函数 即自己调用自己,递归中可以函数自身调用自身,但是使用时类似于条件循环一样,要有递归的终止条件 优点:使用递归时,常常可以让代码更加简洁 缺点:递归会占用比较多的内存,当递归次数比较多时,性能 ...

  3. 爬虫app信息抓取之apk反编译抓取

    之前也抓过一些app,数据都比较好取,也没有研究的太深,毕竟还有android 模拟器+ appium 的方法.直到遇见了一款app ,具体名字就不说了,它安装在模拟器上竟然打不开 !!第一次遇见上网 ...

  4. luoguT21778 过年

    差分一下上线段树 #include <iostream> #include <cstdio> #include <vector> using namespace s ...

  5. 【MVC 2】MVC+EF框架结构实例:注册ID号验证

    导读:本篇博客,将通过一个实例,详细介绍MVC+EF的应用.原理性的东西或者说是进一步的解耦和,请看博客: [框架结构 3]MVC+EF实体框架-原理解析.在这里,仅用MVC框架和一个EF生成的Mod ...

  6. POJ3246-Balanced Lineup,好经典的题,做法和HDU-I hate it 一样~~

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K   Case Time Limit: 2000MS Description For ...

  7. 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 ...

  8. 【随机化算法】codeforces Matrix God

    http://codeforces.com/gym/101341 [题意] 给定三个方阵A,B,C,问AB=C是否成立? 方阵的规模最大为1000 [思路] 求AB的时间复杂度为n*n*n,会超时 左 ...

  9. 《TCP/IP详解卷1:协议》——第5章 RARP:逆地址解析协议(转载)

    1.引言 具有本地磁盘的系统引导时,一般是从磁盘上的配置文件中读取IP地址.但是无盘机,如X终端或无盘工作站,则需要采用其他方法来获得IP地址. 网络上的每个系统都具有唯一的硬件地址,它是由网络接口生 ...

  10. Linux内核设计与实现——读书笔记1:内核简介

    内核:有的时候被称管理者或者操作系统核心,通常内核负责响应中断的中断服务程序, 负责管理多个进程从而分享处理器时间的调度程序,负责管理进程地址空间德内存管理程序 和网络,进程间通信等系统服务程序共同组 ...