使用装饰器后,视图函数名字相同问题view function错误问题 1.给装饰器加functiontools 2.反向生成url地址标志,指定endpoint(endpoint必须惟一)
from flask import Flask,session,request,redirect,render_template app = Flask(__name__) app.secret_key = 'lilz' def outer(func): def inner(): print('success') func() # return 'ok' return inner @app.route('/') @outer def index(): if not session.get('user'): return redirect('/login') return render_template('index.html') @app.route('/login',methods=['GET','POST']) @outer def login(): if request.method == 'POST': if request.form.get('username') == 'lilz' and request.form.get('password'): session['user'] = request.form.get('username')+'666' return redirect('/') else: return render_template('login.html') app.run(debug=True)
启动程序会报错html
缘由:json
@outer 装饰器返回的是inner,因此两个加了 @outer装饰器的函数都是inner,就会报错
解决方案:flask
方式一:functools缓存
import functools from flask import Flask,session,request,redirect,render_template app = Flask(__name__) app.secret_key = 'lilz' #-------自定义装饰器--------------------------------- def outer(func): @functools.wraps(func) def inner(): print('success') func() # return 'ok' return inner @app.route('/') @outer def index(): if not session.get('user'): return redirect('/login') return render_template('index.html') @app.route('/login',methods=['GET','POST']) @outer def login(): if request.method == 'POST': if request.form.get('username') == 'lilz' and request.form.get('password'): session['user'] = request.form.get('username')+'666' return redirect('/') else: return render_template('login.html') app.run(debug=True)
`functools.wraps 则能够将原函数对象的指定属性复制给包装函数对象, 默认有 __module__、__name__、__doc__`
方式二:endpoint安全
反向生成url地址标志 默认视图函数名 服务器
from flask import Flask,session,request,redirect,render_template,url_for app = Flask(__name__) app.secret_key = 'lilz' def outer(func): def inner(): print('success') func() return 'ok' return inner @app.route('/', endpoint="index") @outer def index(): if not session.get('user'): return redirect('/login') return render_template('index.html') @app.route('/login',methods=['GET','POST'],endpoint="login") @outer def login(): return 'enen' app.run(debug=True)
@app.route("/") 1.methods=["GET","POST"] :只有列表中的访问方式才能够执行该视图函数 2.endpoint="index" :反向url地址,默认为视图函数名 3.defaults={"nid"="123"} :默认参数 4.strict_slashes=True(Flase) :是否严格遵循路由地址规则,后面可不能够加/ 5.redirect_to="/index" :永久重定向(一般用于网站永久更改地址) 6.int与string:以下图,动态路由参数(视图函数中要接受page) float:@app.route("/index/<float:post_id>) path:@app.route("/index/<path:path>)
app=Flask(__name__) 1.app=Flask(__name__,template_folder="temp")#指定模板路径 2.app=Flask(__name__,static_folder="statics")#静态文件目录 app=Flask(__name__,static_url_path="/static")#遇到/static时,找static_folder,静态目录和静态文件路径地址的区别 static_url_path默认是static_folder前加一个/ ######################################3 4.static_host=None #指定静态文件服务器地址 5.host_matching = False, # 若是不是特别须要的话,慎用,不然全部的route 都须要host=""的参数,必须得有SERVER_NANME才有用 6.instance_path = None, # 指向另外一个Flask实例的路径 7.instance_relative_config = False # 是否加载另外一个实例的配置 8.root_path = None # 主模块所在的目录的绝对路径,默认项目目录
app.secret_key="shy" app.config["SECRET_KEY"]="shy" #也能够这样配置SECRET_KEY
{ 'DEBUG': False, # 是否开启Debug模式, 'TESTING': False, # 是否开启测试模式 区别:DEBUG能够重启,TESTING不能够重启,TESTING在控制台中能够看到全部的信息 'PROPAGATE_EXCEPTIONS': None, # 是否开启异常传播(是否在控制台打印LOG) 当Debug或者testing开启后,自动为True 'PRESERVE_CONTEXT_ON_EXCEPTION': None, # 一两句话说不清楚,通常不用它 'SECRET_KEY': None, # 以前遇到过,在启用flask内置Session(或开启闪现时)的时候,必定要有它 'PERMANENT_SESSION_LIFETIME': 31, # days , Session的生命周期(天)默认31天 'USE_X_SENDFILE': False, # 是否弃用 x_sendfile 'LOGGER_NAME': None, # 日志记录器的名称 'LOGGER_HANDLER_POLICY': 'always', 'SERVER_NAME': None, # 服务访问域名 'APPLICATION_ROOT': None, # 项目的完整路径 !!!!!!!!!! 'SESSION_COOKIE_NAME': 'session', # 在cookies中存放session加密字符串的名字 'SESSION_COOKIE_DOMAIN': None, # 在哪一个域名下会产生session记录在cookies中 'SESSION_COOKIE_PATH': None, # cookies的路径 'SESSION_COOKIE_HTTPONLY': True, # 控制 cookie 是否应被设置 httponly 的标志, 'SESSION_COOKIE_SECURE': False, # 控制 cookie 是否应被设置安全标志 'SESSION_REFRESH_EACH_REQUEST': True, # 这个标志控制永久会话如何刷新 'MAX_CONTENT_LENGTH': None, # 若是设置为字节数, Flask 会拒绝内容长度大于此值的请求进入,并返回一个 413 状态码 'SEND_FILE_MAX_AGE_DEFAULT': 12, # hours 默认缓存控制的最大期限 'TRAP_BAD_REQUEST_ERRORS': False, # 若是这个值被设置为 True ,Flask不会执行 HTTP 异常的错误处理,而是像对待其它异常同样, # 经过异常栈让它冒泡地抛出。这对于须要找出 HTTP 异常源头的可怕调试情形是有用的。 'TRAP_HTTP_EXCEPTIONS': False, # Werkzeug 处理请求中的特定数据的内部数据结构会抛出一样也是“错误的请求”异常的特殊的 key errors 。 # 一样地,为了保持一致,许多操做能够显式地抛出 BadRequest 异常。 # 由于在调试中,你但愿准确地找出异常的缘由,这个设置用于在这些情形下调试。 # 若是这个值被设置为 True ,你只会获得常规的回溯。 'EXPLAIN_TEMPLATE_LOADING': False, 'PREFERRED_URL_SCHEME': 'http', # 生成URL的时候若是没有可用的 URL 模式话将使用这个值 'JSON_AS_ASCII': True, # 默认状况下 Flask 使用 ascii 编码来序列化对象。若是这个值被设置为 False , # Flask不会将其编码为 ASCII,而且按原样输出,返回它的 unicode 字符串。 # 好比 jsonfiy 会自动地采用 utf-8 来编码它而后才进行传输。 'JSON_SORT_KEYS': True, #默认状况下 Flask 按照 JSON 对象的键的顺序来序来序列化它。 # 这样作是为了确保键的顺序不会受到字典的哈希种子的影响,从而返回的值每次都是一致的,不会形成无用的额外 HTTP 缓存。 # 你能够经过修改这个配置的值来覆盖默认的操做。但这是不被推荐的作法由于这个默认的行为可能会给你在性能的代价上带来改善。 'JSONIFY_PRETTYPRINT_REGULAR': True, 'JSONIFY_MIMETYPE': 'application/json',#根据jsonify来更改响应头中的contentType 'TEMPLATES_AUTO_RELOAD': None, }
有意义cookie
三种模式下切换太麻烦,用一个类(对象)来控制session
class FlaskDebug(object): DEBUG=True SECRET_KEY="DEBUGmoshidesecret_key" PERMANENT_SESSION_LIFETIME = 7 SESSION_COOKIE_NAME = "debug_session" class FlaskTesting(object): TESTING=True SECRET_KEY="TESTINGmoshidesecret_key" PERMANENT_SESSION_LIFETIME = 15 SESSION_COOKIE_NAME = "TESTING_session"
编写数据结构
导入app
访问:192.168.177.130:5000/app01
url前缀
注册时加url前缀也行
若是两个不同,以注册为准
存进去,取出来就消失了
存与取
只执行一次get_dlashed_messages里面全部的东西都没了
请求进入视图函数以前执行
先登陆才能进入视图函数
能够有多个before_request
二者的执行顺序
出现错误时换个页面,自动播放歌曲
@app.errorhandler(404) def error404(args): print(args) return render_template("error.html")
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>Title</title> <meta name="viewport" content="width=device-width, initial-scale=1"> </head> <body> <h1>您访问的页面出现了异常</h1> <audio src="/static/goout.mp3" autoplay></audio> </body> </html>