zoukankan      html  css  js  c++  java
  • flask(2)

    URL路径参数

    转换器

    from flask import Flask
    app =Flask(__name__)
    
    #/user/123
    @app.route('/user/<int:user_id>')#int:规定只能输入该类型字符 并自动帮你转成该类型
    def get_user_id(user_id):
        return 'get users {}.'.format(user_id)
    
    if __name__ == '__main__':
        app.run()

    Flask也提供其他类型的转换器

    DEFAULT_CONVERTERS = {
        'default':          UnicodeConverter,
        'string':           UnicodeConverter,
        'any':              AnyConverter,
        'path':             PathConverter,
        'int':              IntegerConverter,
        'float':            FloatConverter,
        'uuid':             UUIDConverter,
    }
    自定义转化器
    from flask import Flask
    from werkzeug.routing import BaseConverter
    
    #自定义转化器
    class Mobile(BaseConverter):
        regex = r'1[1-9]d{9}'
    
    #创建应用
    app =Flask(__name__)
    
    #将自定义转换器添加到转换器字典中,并指定转化器使用名字为: mobile
    app.url_map.converters['mobile'] = Mobile
    
    #/user/123
    @app.route('/user/<mobile:user_id>')#int:规定只能输入该类型字符 并自动帮你转成该类型
    def get_user_id(user_id):
        return 'get users {}.'.format(user_id)
    
    if __name__ == '__main__':
        app.run()


    flask的request

    不同位置的参数都存放在request的不同属性中

    属性说明类型
    data 记录请求的数据,并转换为字符串 *
    form 记录请求中的表单数据 MultiDict
    args 记录请求中的查询参数 MultiDict
    cookies 记录请求中的cookie信息 Dict
    headers 记录请求中的报文头 EnvironHeaders
    method 记录请求使用的HTTP方法 GET/POST
    url 记录请求的URL地址 string
    files 记录请求上传的文件 *

    例如 想要获取请求/articles?channel_id=1channel_id的参数,可以按如下方式使用:

    from flask import request
    
    @app.route('/articles')
    def get_articles():
          channel_id = request.args.get('channel_id')
        return 'you wanna get articles of channel {}'.format(channel_id)

    处理响应

    #响应处理
    from flask import Flask,render_template #导入渲染模板的类
    
    app = Flask(__name__)
    
    @app.route('/')
    def home():
        str = '我草'
        int = 123
        content = dict(
            my_str ='你妈',
            my_int = 456
        )
        # return render_template('index.html',my_str =str,my_int = int) #第一种渲染方式 
        return render_template('index.html', **content) #第二种渲染方式 content里的变量名必须与模板中的一致
    
    if __name__ == '__main__':
        app.run()

    重定向

    from flask import redirect
    
    @app.route('/demo2')
    def demo2():
        return redirect('http://www.itheima.com')

    返回json

    from flask import jsonify
    
    @app.route('/demo3')
    def demo3():
        json_dict = {
            "user_id": 10,
            "user_name": "laowang"
        }
        return jsonify(json_dict)

    自定义状态码和响应头

    1 元祖方式

    可以返回一个元组,这样的元组必须是(response,status,headers)的形式,并且至少包含一个元素。status值会覆盖状态代码,headers可以是一个列表或字典,作为额外的消息标头值。

    @app.route('/demo4')
    def demo4():
        # return '状态码为 666', 666
        # return '状态码为 666', 666, [('Itcast', 'Python')]
        return '状态码为 666', 666, {'Itcast': 'Python'}

    2 make_response方式

    @app.route('/demo5')
    def demo5():
        resp = make_response('make response测试')
            resp.headers[“Itcast”] = “Python”
            resp.status = “404 not found”
        return resp

    cookie

    设置

    @app.route('/cookie')
    def set_cookie():
        response = make_response('hello world')#只能用make构造返回 因为后续还要设置cookie 如果直接return响应 就不能设置cookie
        response.set_cookie('username', 'itheima', max_age=3600)
        return response

    读取

    from flask import request
    
    @app.route('/get_cookie')
    def get_cookie():
        resp = request.cookies.get('username')
        return resp

    删除

    from flask import request
    
    @app.route('/delete_cookie')
    def delete_cookie():
        response = make_response('hello world')
        response.delete_cookie('username')
        return response

    Session

    flask把session存在浏览器上 但是是经过服务器的secret_key签名的 

    需要先设置SECRET_KEY

    class DefaultConfig(object):
        SECRET_KEY = 'fih9fh9eh9gh2'
    
    app.config.from_object(DefaultConfig)
    
    或者直接设置
    app.secret_key='xihwidfw9efw'

    设置session

    from flask import session
    
    @app.route('/set_session')
    def set_session():
        session['username'] = 'itcast'
        return 'set session ok'

    读取

    @app.route('/get_session')
    def get_session():
        username = session.get('username')
        return 'get session username {}'.format(username)

    异常处理

    • 方法
      • 抛出一个给定状态代码的HTTPException或指定响应,例如想要用一个页面未找到异常来终止请求,你可以调用abort(404)。
    • 参数:
      • 代码– HTTP的错误状态码
    # abort(404)
    abort(500)

    • 捕获指定异常
    @app.errorhandler(ZeroDivisionError)
    def zero_division_error(e):
        return '除数不能为0'

    请求钩子

    在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比如:

    • 在请求开始时,建立数据库连接;
    • 在请求开始时,根据需求进行权限校验;
    • 在请求结束时,指定数据的交互格式;

    为了让每个视图函数避免编写重复功能的代码,Flask提供了通用设施的功能,即请求钩子。

    请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子:

    • before_first_request
      • 在处理第一个请求前执行
    • before_request
      • 在每次请求前执行
      • 如果在某修饰的函数中返回了一个响应,视图函数将不再被调用
    • after_request
      • 如果没有抛出错误,在每次请求后执行
      • 接受一个参数:视图函数作出的响应
      • 在此函数中可以对响应值在返回之前做最后一步修改处理
      • 需要将参数中的响应在此参数中进行返回
    • teardown_request:
      • 在每次请求后执行
      • 接受一个参数:错误信息,如果有相关错误抛出
    from flask import Flask
    from flask import abort
    
    app = Flask(__name__)
    
    
    # 在第一次请求之前调用,可以在此方法内部做一些初始化操作
    @app.before_first_request
    def before_first_request():
        print("before_first_request")
    
    
    # 在每一次请求之前调用,这时候已经有请求了,可能在这个方法里面做请求的校验
    # 如果请求的校验不成功,可以直接在此方法中进行响应,直接return之后那么就不会执行视图函数
    @app.before_request
    def before_request():
        print("before_request")
        # if 请求不符合条件:
        #     return "laowang"
    
    
    # 在执行完视图函数之后会调用,并且会把视图函数所生成的响应传入,可以在此方法中对响应做最后一步统一的处理
    @app.after_request
    def after_request(response):
        print("after_request")
        response.headers["Content-Type"] = "application/json"
        return response
    
    
    # 请每一次请求之后都会调用,会接受一个参数,参数是服务器出现的错误信息
    @app.teardown_request
    def teardown_request(e):
        print("teardown_request")
    
    
    @app.route('/')
    def index():
        return 'index'
    
    if __name__ == '__main__':
        app.run(debug=True)

    上下文(上下文实现原理:threadlocal--线程局部变量)

    上下文:即语境,语意,在程序中可以理解为在代码执行到某一时刻时,根据之前代码所做的操作以及下文即将要执行的逻辑,可以决定在当前时刻下可以使用到的变量,或者可以完成的事情。

    Flask中有两种上下文,请求上下文和应用上下文

    Flask中上下文对象:相当于一个容器,保存了 Flask 程序运行过程中的一些信息。

    请求上下文(request context)

    思考:在视图函数中,如何取到当前请求的相关数据?比如:请求地址,请求方式,cookie等等

    在 flask 中,可以直接在视图函数中使用 request 这个对象进行获取相关数据,而 request 就是请求上下文的对象,保存了当前本次请求的相关数据,请求上下文对象有:request、session

    • request
      • 封装了HTTP请求的内容,针对的是http请求。举例:user = request.args.get('user'),获取的是get请求的参数。
    • session
      • 用来记录请求会话中的信息,针对的是用户信息。举例:session['name'] = user.id,可以记录用户信息。还可以通过session.get('name')获取用户信息。

    应用上下文(application context)

    它的字面意思是 应用上下文,但它不是一直存在的,它只是request context 中的一个对 app 的代理(人),所谓local proxy。它的作用主要是帮助 request 获取当前的应用,它是伴 request 而生,随 request 而灭的。

    应用上下文对象有:current_app,g

    current_app(在蓝图里使用全局变量)

    应用程序上下文,用于存储应用程序中的变量,可以通过current_app.name打印当前app的名称,也可以在current_app中存储一些变量,例如:

    • 应用的启动脚本是哪个文件,启动时指定了哪些参数
    • 加载了哪些配置文件,导入了哪些配置
    • 连了哪个数据库
    • 有哪些public的工具类、常量
    • 应用跑再哪个机器上,IP多少,内存多大
     

    g变量(仅在一次请求中有效)

    g 作为 flask 程序全局的一个临时变量,充当者中间媒介的作用,我们可以通过它传递一些数据,g 保存的是当前请求的全局变量,不同的请求会有不同的全局变量,通过不同的thread id区别

  • 相关阅读:
    第九周进度条
    梦断代码阅读笔记01
    NABCD分析
    软件工程个人作业05
    HDU 3949 XOR(线性基)
    luogu 2115 破坏(01分数规划)
    luogu 1360 阵容均衡(前缀和+差分+hash)
    luogu 1967 货车运输(最大生成树+LCA)
    luogu 1344 追查坏牛奶(最小割)
    BZOJ 2007 海拔(平面图最小割转对偶图最短路)
  • 原文地址:https://www.cnblogs.com/xujin247/p/11743732.html
Copyright © 2011-2022 走看看