1.装饰器坑

使用装饰器后,视图函数名字相同问题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')+''
return redirect('/')
else:
return render_template('login.html')


app.run(debug=True)

启动程序会报错

原因

 
 @outer  装饰器返回的是inner,所以两个加了 @outer装饰器的函数都是inner,就会报错

解决方案:

方式一: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')+''
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)

2.flask中的路由

@app.route("/")
1.methods=["GET","POST"] :只有列表中的访问方式才可以执行该视图函数
2.endpoint="index" :反向url地址,默认为视图函数名
3.defaults={"nid"=""} :默认参数
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>)

3.flask实例化配置

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 # 主模块所在的目录的绝对路径,默认项目目录

4.flask对象配置

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,
}

有意义

三种模式下切换太麻烦,用一个类(对象)来控制

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"

5.flask蓝图(blueprint)相当于一个可插拔的app

编写

导入

访问:192.168.177.130:5000/app01

url前缀

注册时加url前缀也行

如果两个不一样,以注册为准

6.flask中的flash(闪现)

存进去,取出来就消失了

存与取

只执行一次get_dlashed_messages里面所有的东西都没了

7.特殊装饰器(s4)

1.@app.before_request:类似于中间件

请求进入视图函数之前执行

先登录才能进入视图函数

可以有多个before_request

2.@app.after_request:在相应客户端之前

两者的执行顺序

3.@app.errorhandler(404) #重定义错误页面返回信息

出现错误时换个页面,自动播放歌曲

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

flask(二)的更多相关文章

  1. flask(二)之Jinja2模板与Flask-WTF

    01-文档 官方文档:http://docs.jinkan.org/docs/jinja2/ 02-基本语义 Jinja2做构成的模板文件中,文本内容大致可以分成几个种类.比如特殊文本(不进行转义,比 ...

  2. Flask (二) cookie 与 session 模型

    会话技术 Cookie 客户端端的会话技术 cookie本身由浏览器保存,通过Response将cookie写到浏览器上,下一次访问,浏览器会根据不同的规则携带cookie过来 ​ 特点:   - 客 ...

  3. Python3+Flask安装使用教程

    一.环境配置 当前我的开发环境是Miniconda3+PyCharm.开发环境其实无所谓,自己使用Python3+Nodepad都可以.安装Flask库: pip install Flask 二.第一 ...

  4. Python——Flask框架——程序的基本结构

    一.安装 pip install flask 二.初始化 from flask import Flask app = Flash(__name__) 三.路由:处理URL和函数之间的关系的程序称为路由 ...

  5. Python学习之web框架 Flask

    一.通过PIP 安装Flask 1.1 Windows环境安装pip A.首先PIP进入官网(https://pypi.python.org/pypi/pip)下载gz包 B.对gz压缩包进行解压,解 ...

  6. Python web框架 flask

    Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后 ...

  7. Flask 学习之flask入门

    一.Flask的简单介绍 Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请 ...

  8. 初识Flask、快速启动

    目录 一.初识Flask 1.1 什么是flask? 1.2 为什么要有flask? 二.Flask快速启动 一.初识Flask 1.1 什么是flask? Flask 本是作者 Armin Rona ...

  9. flask实现python方法转换服务

    一.flask安装 pip install flask 二.flask简介: flask是一个web框架,可以通过提供的装饰器@server.route()将普通函数转换为服务 flask是一个web ...

随机推荐

  1. Maven打包不打test,Maven中-DskipTests和-Dmaven.test.skip=true的区别

    在使用mvn package进行编译.打包时,Maven会执行src/test/java中的JUnit测试用例, 有时为了跳过测试,会使用参数-DskipTests和-Dmaven.test.skip ...

  2. Go语言并发

    Go语言并发机制初探   Go 语言相比Java等一个很大的优势就是可以方便地编写并发程序.Go 语言内置了 goroutine 机制,使用goroutine可以快速地开发并发程序, 更好的利用多核处 ...

  3. 如何向数据库添加时同时返回ID

    我们在做项目开发时很多时候都需要数据库的增删改查,而添加数据后又想得到该项数据在数据库中的主键值,这里有一个非常方便的方法可以在插入数据的同时获得主键值. public void save(Perso ...

  4. mongdb aggregate 聚合数据

    最近用到的一些mongodb的数据查询方法 及api用法 Aggregate() 数据聚合处理的方法 可以将聚合的一些方法放在其后面的括号中,也可继续以agg.的样式链式加入 aggregate.al ...

  5. zoj 3820 Building Fire Stations(二分法+bfs)

    题目链接:zoj 3820 Building Fire Stations 题目大意:给定一棵树.选取两个建立加油站,问说全部点距离加油站距离的最大值的最小值是多少,而且随意输出一种建立加油站的方式. ...

  6. linux awk(good)

    一个用awk处理字符串的例子: #!/bin/bash source="nokia201703148855" preffixStr=$(echo $source |awk '{pr ...

  7. 3 WCF一些基础铺垫

    1首先上一张wcf通讯图 a.Proxy代理部分底层调用的是 xxxxClient=> ChannelFactory=>IInpuChannel/IOutChannel... b.Tran ...

  8. 利用WPF的ListView进行大数据量异步加载

    原文:利用WPF的ListView进行大数据量异步加载 由于之前利用Winform的ListView进行大数据量加载的时候,诟病良多,所以今天试着用WPF的ListView来做了一下,结果没有让我失望 ...

  9. echarts学习(上)

    echarts 学习之路 学习思路 初识echarts 编写自己的echarts图表 根据需求编写工作中的echarts图表[进阶篇] github地址:https://github.com/liso ...

  10. 开源 自由 java CMS - FreeCMS1.9 积分规则管理

    项目地址:http://www.freeteam.cn/ 积分规则管理 管理会员操作时积分处理规则. 1. 积分规则管理 从左側管理菜单点击积分规则进入. 2. 加入积分规则 在积分规则列表下方点击& ...