Flask小总结+实例化Flask参数以及对app的配置

摘要:
jsonifyreturnsend_File()打开并返回文件内容returnjsonify()内容类型:当前项目中的默认模板目录*static_Folder=“jingtaiwenjianulu”目录*static_curl_Path=“/static”访问路径static_host=“http:

    Flask 小而精 三方组件全 
    稳定性相对较差
    
    1.启动:
        from flask import Flask
        app = Flask(__name__)
        app.run("0.0.0.0",5000,debug=True)
        
    2.加入路由
        @app.route("/",methods=("GET","POST"))
        def index():
            return "123"
            
    3.Response三剑客 + 小儿子:
        HTTPResponse return "httpresponse"
        from flask import redirect
        redirect: return redirect("/")
        from flask import render_template
        render: return render_template - templates
        小儿子:
        from flask import send_file , jsonify        
        return send_file() 打开并返回文件内容
        return jsonify() Content-Type: application/json
    
    4.request 
        from flask import request 公共变量 - 数据安全性?
        request.form 表单数据,FormData 字典 to_dict
        request.args URL中的参数,数据
        request.json Content-Type:application/json 请求头
        request.data Content-Type不被认可 将原始数据存放在data b""
        request.values 存放 FormData URL 一般情况下 to_dict
        request.files 获取文件 save 保存
        request.method
        request.path
        
    5.Jinja:
        {{}} 引用和执行
        {%%} 逻辑代码
    
    6.session: Flask-session
        将 session 加密后存放在浏览器的 Cookie
        from flask import session
        app.secret_key = "ward1"  
        session["user"] = "ward2"
        session.get("user")
        
    
    写装饰器 基于session 验证用户有效性


    1.Flask 中的路由 
        *endpoint - url_for 反向地址
        *endpoint 默认是视图函数名
        *methods 指定视图函数的请求方式,默认GET
        defaults={"nid":1} 指定视图函数的默认参数
        strict_slashes=False 是否严格遵循路由规则 /login/
        redirect_to="/login" 永久跳转地址 301
        
        *动态路由参数:
        /<int:nid>  /<string:str> /<nid> 
        视图函数中需要有参数接收动态路由参数
        
    2.Flask中的实例化配置
        *template_folder = "temp"  # template模板目录, 默认当前项目中的 templates 目录
        *static_folder = "jingtaiwenjianmulu" 目录
        *static_url_path = "/static" 访问路径
        static_host = "http://xx.xxx.com/static"  cdn静态文件服务器配置
        
        host_matching = False,  # 如果不是特别需要的话,慎用,否则所有的route 都需要host=""的参数
        subdomain_matching = False,  # 理论上来说是用来限制SERVER_NAME子域名的,但是目前还没有感觉出来区别在哪里
        instance_path = None,  # 指向另一个Flask实例的路径
        instance_relative_config = False  # 是否加载另一个实例的配置
        root_path = None  # 主模块所在的目录的绝对路径,默认项目目录
        
    3.app对象配置
        app.config.from_object(Debug)
        class Debug(object):
            DEBUG=True
    
    4.蓝图 Blueprint
        form flask import Blueprint
        blue = Blueprint("blue_id",__name__,url_prefix)
        url_prefix 前缀
        app.register_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):
        
    基于蓝图实现增删改查数据 基于Before_request session 实现用户校验
    可选errorhandler
               
1.CBV :
    from flask import views
    
    class LoginView(views.MethodView):
        def get(self):
            return
            
        def post(self):
            return
            
    
    app.add_url_rule("/login",endpoint=None,view_func=LoginView.as_view("login"))
    
2.flash:
    from flask import flash,get_flash_messages
    
    flash("","tag")
    get_flash_messages("tag")
    

3.Flask-Session
    from flask_session import Session
    from flask import session
    
    app.config["SESSION_TYPE"] = "redis"
    app.config["SESSION_REDIS"] = Redis("127.0.0.1",6379,db=7)
    Session(app)
    
    session["user"] == "123"
    session.get("user")
    


4.WTForms - MoudelForm
    from wtfroms.fields import simple,core
    from wtfroms import Form,validators
    
    class LoginForm(Form):
        username = simple.StringFields(
            label = "" #看源码 __init__
        )
        
    
    lf = LoginForm()
    render_template("html",lf=lf)
    
    {{ lf.uername }}
    {{ lf.uername.label }}
    {{ lf.uername.errors.0 }}
    
    lf = LoginForm(request.form)
    
    if not lf.validata():
        render_template("html",lf=lf)
    
    lf.data.get("username")
    
实例化Flask参数以及对app的配置
 

Flask 是一个非常灵活且短小精干的web框架 , 那么灵活性从什么地方体现呢?

有一个神奇的东西叫 Flask配置 , 这个东西怎么用呢? 它能给我们带来怎么样的方便呢?

首先展示一下:

from flask import Flask

app = Flask(__name__)  # type:Flask
app.config["DEBUG"] = True

这句 app.config["DEBUG"] = True 可以实现的功能可刺激了

代码只要发生改动,自动重启Flask程序(app.run)

在控制台打印的信息非常全面

以上两个功能就是传说中的 DEBUG 模式(调试模式)

Flask的配置就是在 app.config 中添加一个键值对,但是你存进去的键必须是config中应该存在的,如果不再存在的话,它会默认无用,就这么放着

config中有多少有用的key 呢?

{
    'DEBUG': False,  # 是否开启Debug模式
    'TESTING': False,  # 是否开启测试模式
    'PROPAGATE_EXCEPTIONS': None,  # 异常传播(是否在控制台打印LOG) 当Debug或者testing开启后,自动为True
    'PRESERVE_CONTEXT_ON_EXCEPTION': None,  # 一两句话说不清楚,一般不用它
    'SECRET_KEY': None,  # 之前遇到过,在启用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',
    'TEMPLATES_AUTO_RELOAD': None,
}

以上这些Key,都可以被改写,当然他们也都是有默认值存在的,如果没有特殊情况,不要改写它的默认值

修改配置的方式大约是两种

1.直接对app.config进行修改

app.config["DEBUG"] = True

2.使用类的方式导入

首先要有一个settings.py的文件

class FlaskSetting:
    DEBUG = True
    SECRET_KEY = "DragonFire"

然后我们在Flask的启动文件中就可以这么写

from flask import Flask


app = Flask(__name__)  # type:Flask
app.config.from_object("settings.FlaskSetting")

这叫做类导入配置

这是针对一个已经实例化的app进行的配置

那么在Flask实例化的时候,传递的参数是什么鬼呢?

其实可以理解为对Flask实例进行的初始配置,这里面的参数是非常好理解,注意关键字是非常非常非常好理解

static_folder = 'static',  # 静态文件目录的路径 默认当前项目中的static目录
static_host = None,  # 远程静态文件所用的Host地址,默认为空
static_url_path = None,  # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时复用
# host_matching是否开启host主机位匹配,是要与static_host一起使用,如果配置了static_host, 则必须赋值为True
# 这里要说明一下,@app.route("/",host="localhost:5000") 就必须要这样写
# host="localhost:5000" 如果主机头不是 localhost:5000 则无法通过当前的路由
host_matching = False,  # 如果不是特别需要的话,慎用,否则所有的route 都需要host=""的参数
subdomain_matching = False,  # 理论上来说是用来限制SERVER_NAME子域名的,但是目前还没有感觉出来区别在哪里
template_folder = 'templates'  # template模板目录, 默认当前项目中的 templates 目录
instance_path = None,  # 指向另一个Flask实例的路径
instance_relative_config = False  # 是否加载另一个实例的配置
root_path = None  # 主模块所在的目录的绝对路径,默认项目目录

这里面,我们常用的参数有

static_folder = 'static',  # 静态文件目录的路径 默认当前项目中的static目录
static_url_path = None,  # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时复用
template_folder = 'templates'  # template模板目录, 默认当前项目中的 templates 目录

记住这些就好了,一般的项目中,只修改这些参数

免责声明:文章转载自《Flask小总结+实例化Flask参数以及对app的配置》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇数据库启动的三个台阶nomount,mount,open(转载)移动端及vue相关问题下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

使用NTP获取网络时间-----java

在做系统对时的时候,需要使用到ntp来获取时间。 可以使用common-net包来获取ntp服务器的时间(即可以向那些标准时间服务器对时,也可以向自己设置好的ntp服务器进行对时)。 使用java获取ntp的时间(t1,t2,t3,t4)。下面是官网上给出的关于使用common-net关于ntp部分的使用例子。 如果要与指定服务器A对时(非NTP时间服务器...

uniapp app-plus pages.json

app-plus Object 设置编译到 App 平台的特定样式,配置项参考下方 app-plus App 参考地址 https://uniapp.dcloud.io/collocation/pages app-plus配置编译到 App 平台时的特定样式,部分常用配置 H5 平台也支持。以下仅列出常用,更多配置项参考 WebviewStyles。 ti...

js瀑布流 原理实现揭秘 javascript 原生实现

  web,js瀑布流揭秘   瀑布流再很久之前流行,可能如我一样入行晚的 ,可能就没有机会去使用。但是这个技术终究是个挺炫酷的东西,花了一个上午来研究,用原生js实现了一个,下面会附上源码,供大家解读。   说起瀑布流,其实实现原理特别简单,而且方法有很多,现在说一个大众的方法,所谓瀑布流就是 一堆样式差不多的 盒子排列在一起,排列规则是,插入到高度最低...

使用XDocReport将HTML格式数据转换为Word

文档地址:https://github.com/opensagres/xdocreport/wiki/DocxReportingQuickStart 本文采用XDocReport集合Freemaiker进行处理 1. 引入Maven依赖: <dependency> <groupId>fr.opensagres.xdocre...

教你如何在iPhone AppStore赚钱

现在iPhone销售不断飙升,iPhone无疑是目前最炙热的开发平台之一.  iPhone开发者只需要好好的做自己的app, 销售收款物流交易和发布渠道全部由Apple搞定, 收入3:7, Apple 3, 开发者7.   无疑, 初期几个很成功的app让一批人赚了第一桶金子.  当然大家都跃跃欲试的时候, iPhone的开发也就有点开始白菜化的趋势.  ...

Guideline 5.2.1

      最近在上架公司公司项目的时候遇到这个问题什么5.2.1 然后去了解发现最近不少人都遇到了这个问题.先说一下 我上架的APP是一个医疗的APP然后说需要什么医疗资质,估计是账号的公司资质不够吧。后面和苹果电话,对方要求提供医院相关的医疗资质,公司都没和医院合作当然无法提供医疗资质了,然后和苹果交流,告诉对方我们的APP只提供健康咨询,健康问诊,不...