zoukankan      html  css  js  c++  java
  • Flask 基础总结回顾

    1.Flask Request

    # from flask import request
    		request.form # 获取FormData中的数据
    		request.args # 获取URL中的数据
    		request.data # 获取原始请求体数据 content-type 中没有Form字眼 b""
    		request.json # 获取 content-type:application/json 字典
    		request.files # 获取请求中的文件数据 FileStorage 对象 save(文件路径)
    		request.method # 获取请求方式 GET POST DELETE PUT
            request.path # 获取请求路径 路由地址
            request.host_url # 获取请求HOST地址
            request.cookies # 获取Cookie对象
            request.headers # 获取请求头中的数据
    

    2.Flask Response

    1."" HTTPResponse
    2.render_templates(模板名称) # 默认模板存放路径 templates
    3.redirect("/路由地址") # 响应头中 location:http://url/路由地址
    Flask 特殊:
    4.send_file("文件路径")
    # 打开并返回文件件内容 自动识别文件类型 响应头 Content-Type:文件类型
    5.jsonify(dict)
    # 返回标注的JSON格式字符串 响应头 Content-Type:application/json
    

    3.Flask 中的 Session

    from flask import session
    application.secret_key = "$%^&*()&^%$%^&*"
    app.config["SECRET_KEY"] = "$%^&*()&^%$%^&*"
    session["user"] = 123
    
    if session.get("user") ---  session["user"] KeyError
    
    交由客户端保管机制
    1.session["user"] = "123"
    2.序列化session 字符串
    3.通过 SECRET_KEY 加密字符串 加密算法
    4.cookie中加入 {SESSION_COOKIE_NAME}:SECRET_KEY 加密字符串
    5.返回客户端
    
    反:
    1.Cookie获取{SESSION_COOKIE_NAME}:SECRET_KEY
    2.通过 SECRET_KEY 解密 字符串 解密算法
    3.反序列化 字符串 字典 - session
    4.session.get("user")
    

    4.路由

    @app.route("/")
    def index():
    *endpoint app中是唯一的 路由和视图函数之间的桥梁
    *methods 允许请求的方式 ["GET","POST","DELETE","PUT"]
    **动态参数路由
    "/index/<page>"
    "/look/<xiaojiejie>/<picture>"
    def look(xiaojiejie,picture):
    
    defaults = {nid:1} # 视图的默认参数
    strict_slashes # 是否严格遵循路由匹配规则 "/结尾/" True False
    redirect_to # 永久重定向 301 308
    
    app.add_url_rule()
    

    5.初始化

    app = Flask(__name__)
    template_folder # 模板存放路径 os.path.join(root_path,template_folder)
    static_folder # 静态文件存放路径
    static_url_path # 静态文件访问路径 "/{static_folder}"
    -import_name # __name__ 锁定当前文件的目录 保证文件唯一
    -root_path # 当前application的所在目录 由import_name自动创建
    host_matching # 主机位 匹配 config.server_name
    static_host # 远程静态文件服务 "{static_host}/{static_folder}"
    subdomain_matching # 支持子域名的主机位匹配
    instance_path # 另一个Flask示例导入
    instance_relative_config # 另一个FlaskConfig导入
    

    6.配置

    app.config Flask Config对象
    app.debug = True
    app.config["DEBUG"] = True
    DEBUG 		开发环境 log级别低 		重启代码错误透传
    TESTING		测试环境 log级别较高	
    SECRET_KEY  开启Session序列化
    SESSION_COOKIE_NAME 在Cookie Session名称
    SESSION_COOKIE_HTTPONLY 是否只在HTTP请求下开启 session
    JSONIFY_MIMETYPE 更改 jsonify 时的 Content-Type
    	
    class DebugConfig(object):
    			DEBUG = True
    			SECRET_KEY = "%^&*()_"	
    app.config.from_object(DebugConfig)
    

    7.蓝图

    蓝图就是不能Run的Flask示例
    蓝图中没有Config对象
    蓝图的作用 隔离应用 隔离路由
    
    bp = Blueprint("蓝图名称全Flask示例唯一",__name__)
    @bp.route("application路由一致",url_prefix="/url前缀")
    def bp_index():
    app.register_blueprint(bp#蓝图对象)
    

    8.特殊装饰器

    @app.before_request # 在请求进入视图函数之前
    @app.after_request # 在响应客户端之前
        正常:be1 - be2 - vf - af2 - af1
    	异常:be1 - af2 - af1
    	
    @app.errorhandler(404) # 重定义错误信息
    def error404(ErrorMessage):
    	return 5返回
    	
    @app 可是 @bp , @bp 当前的装饰器只生效当前 bp
    

    9.CBV

    试图类
    from flask import views 导入CBV的视图基类
    class Login(views.MethodView): # 继承CBV视图基类的最高类
    def get(self):
        return "GET 200 OK!"
    def post(self):
        return "POST 200 OK!"
    

  • 相关阅读:
    进程管理
    磁盘管理
    用户组管理
    Idea 导入(import)项目和打开(open)项目的区别
    SqlServer--转换varchr值‘2993296307’时溢出了整数列 和 修改 字段类型
    C#--Winform--图标控件Chart详解
    SqlServer--存储过程--自定义存储过程
    SqlServer--存储过程--系统和扩展存储过程(不常用)
    SqlServer--视图
    C#--SqlServer--sql语句拼接和带参数的SQL语句
  • 原文地址:https://www.cnblogs.com/an-wen/p/11601360.html
Copyright © 2011-2022 走看看