• flask --- 02. 路由, 初始化配置,蓝图


    一.Flask 路由

      1.添加路由的方式

      ①

      ②

    实例:
        ①
    @app.route("/my_de") def detail()

        
    ② 
        def detail()
        app.add_url_rule("/my_de",view_func=detail)

      2.常用参数

      ①methods

    methods 的值是 可迭代对象 [] ()
    
    允许请求进入视图函数的方式 8 种HTTP请求方式
    
    没有时默认 只有  "GET"

    实例:

       

      ②endpoint

    endpoint 路由Mapping 地址对应视图函数:
    
    与其对应 - url_for 用来反向解析URL地址 
    url_for(endpoint) # /路由地址

      实例:解决双重装饰器的问题

        (实际上是 endpoint的重名导致)

    方法一:

    方法二:

      ③strict_slashes = True

     url地址结尾符"/"的控制 False : 无论结尾 "/" 是否存在均可以访问 , 
                 True : 结尾必须不能是 "/"
    # 访问地址 : /info 
    @app.route("/info", strict_slashes=True)
    def student_info():
        return "Hello Old boy info"
    
    
    # 访问地址 : /infos  or  /infos/
    @app.route("/infos", strict_slashes=False)
    def student_infos():
        return "Hello Old boy infos"

      ④defaults

    defaults={"nid":3} 默认路由参数 - 视图函数中必须有一个nid(key)的形参接收

    from flask import url_for
    
    
    @app.route("/info", methods=["GET", "POST"], endpoint="r_info", defaults={"nid": 100})
    def student_info(nid):
        print(url_for("r_info"))  # /info
        # stu_id = int(request.args["id"])
        print(nid)  # 100
        return f"Hello Old boy {nid}"  # Python3.6的新特性 f"{变量名}"

      ⑤redirect_to

    redirect_to="/index" 永久重定向 301/?308 - 不进入试图函数处理,直接跳转
    # 访问地址 : /info 浏览器跳转至 /infos
    @app.route("/info", strict_slashes=True, redirect_to="/infos")
    def student_info():
        return "Hello Old boy info"
    
    @app.route("/infos", strict_slashes=False)
    def student_infos():
        return "Hello Old boy infos"

      ⑥动态参数

    @app.route("/detail/<stu_id>") 可以在 路由地址 之后增加参数的传递
        视图函数中必须有一个 stu_id(key) 的形参接收
        例如:
        @app.route("/getimg/<path>/<filename>")
        def getimg(path,filename):
            file_path = os.path.join(path,filename)
            return send_file(file_path)

      在 .html 文件中

      ⑦subdomain

    子域名前缀 subdomian="DragonFire" 这样写可以得到 DragonFire.oldboyedu.com 
    前提是app.config["SERVER_NAME"] = "oldboyedu.com"
    app.config["SERVER_NAME"] = "oldboy.com"
    
    @app.route("/info",subdomain="DragonFire")
    def student_info():
        return "Hello Old boy info"
    
    # 访问地址为:  DragonFire.oldboy.com/info

    二.Flask 配置

      1.Flask初始化配置

    调用时:
    app=Flask(__name__)

    "ctrl键"+点击 Flask

        ①常用的参数

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

      ②所用的参数

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

      2.Flask对象配置

      ①所有配置

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

      ② 修改配置的方式

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

    from flask import Flask
    
    app = Flask(__name__)  # type:Flask
    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")

    三.Flask 蓝图

       ①在一个启动的 app.py 文件中

        from flask import Flask
        from user import bp        #导入
    
        app = Flask(__name__)
    
        app.register_blueprint(bp)  # 注册
    
        if __name__ == '__main__':
            app.run(debug=True)
        

      ② 在蓝图文件 user.py 文件中

        from flask import Blueprint
        # 把Blueprint理解为 不能被 Run 的 Flask 对象
    
        bp = Blueprint("bp",__name__,url_prefix="/user")
                       # bp 蓝图标识 (即蓝图名)
                       # url_perfix = "/user"
                       #  可有可无 访问前缀 为了区分访问 @bp.route(
    "/bp",methods=["GET","Post"]) def my_bp(): return "I am bp in user.py"

    四.蓝图结构

       1.基本结构

     

       2. 基本内容

     

  • 相关阅读:
    ASP.NET MVC & EF 构建智能查询 二、模型的设计与ModelBinder
    ASP.NET MVC & EF 构建智能查询 一、智能查询的需求与设计
    在ASP.NET中自动合并小图片并使用CSS Sprite显示出来
    Entity Framework with MySQL Provider 更新行数为0的Bug
    为ASP.NET MVC 2.0添加Razor模板引擎 (on .NET4)
    ASP.NET MVC 2.0 in Vs2010 :使用C# 4.0中使用动态类型来传递ViewData
    问题贴
    Visual Studio 2010 RC 下安装ASP.NET MVC 2.0 RTM
    Microsoft Ajax CDN与Google Ajax CDN 你来试试哪个快
    ASP.NET MVC & EF 构建智能查询 三、解析QueryModel
  • 原文地址:https://www.cnblogs.com/sc-1067178406/p/10685096.html
Copyright © 2020-2023  润新知