zoukankan      html  css  js  c++  java
  • Flask入门之二

    Flask入门之二

    request对象方法

    与django类似,在视图函数中使用,只不过不需要在入参里写request

    from flask import Flask
    from flask import request
    from flask import render_template
    from flask import redirect
    from flask import make_response
    
    app = Flask(__name__)
    
    
    @app.route('/login.html', methods=['GET', "POST"])
    def login():
        # 请求相关信息
        # request.method  提交的方法:GET/POST
        # request.args  get请求提及的数据
        # request.form   post请求提交的数据
        # request.values  post和get提交的数据总和
        # request.values.getlist('name') 数据中有重名的变量时,这样可以返回一个名为name的值的列表
        # request.cookies  客户端所带的cookie
        # request.headers  请求头
        # request.path     不带域名,请求路径
        # request.full_path  不带域名,带参数的请求路径
        # request.url           带域名带参数的请求路径
        # request.base_url		带域名请求路径
        # request.url_root      域名
        # request.host_url		域名
        # request.host			127.0.0.1:500
        # request.files
        # obj = request.files['the_file_name']
        # obj.save('/var/www/uploads/' + secure_filename(f.filename))
        return "内容"
    
    if __name__ == '__main__':
        app.run()
    

    response对象方法

    直接使用,看不到response对象,可以使用make_response获得这个对象,然后操作cookie,请求头一类的

    from flask import Flask,jsonify,make_response
    # 上一篇博客里讲的lowb三板斧
    return "字符串"
    return render_template('html模板路径',**{})
    return redirect('/index.html')
    
    # 相当于django中的JsonResponse,需要在flask导入
    # 放一个字典,可以转成json字符串
    return jsonify({'k1':'v1'})
    
    aa='hello world'
    # 返回aa,但是aa不是django中的response对象,如果要设置cookie,需要一个对象去set_cookie
    res=make_response(aa)
    # 用make_response生成一个对象,在这里设置cookie
    res.set_cookie('xxx','lqz')
    # 往响应头中放东西
    res.headers['X-Something'] = 'A value'
    print(type(res))
    
    response = make_response(render_template('index.html'))
    response是flask.wrappers.Response类型
    # 删除cookie
    response.delete_cookie('key')
    return response
    

    Session

    from flask import Flask,session
    SECRET_KEY = 'abc'
    # 使用session,必须配置一个secret_key,否则报错
    # 导入session
    # 视图函数中像操作字典一样操作session 
    session['key']=value
    # 删除
    session.pop('key')
    # 取
    session['key']
    

    内置的session,flask直接当作cookie,加密一下返回给浏览器了,如果想存redis或者别的操作,可以指定session类,自己写类或者用第三方完成扩展

    app.session_interface = 自己写的或第三方类
    
    # 类需要重写三个方法:
    open_session
    # 请求来,获取cookie的值到一个字典中,如果没有值,返回一个空,有值,则用get_signing_serializer解码
    
    save_session
    # 请求走,把内容,过期时间等信息加密放进cookie里
    # 内部有监测session.modified,是否session有被动过,动过了就更新整个session(过期时间一类的会刷新)
    
    get_signing_serializer
    # 获取secret_key 里面有load和dump方法,可以加密或者解密
    
    

    闪现

    基于session实现的,所以使用闪现,必须要有secret_key。在一个请求中设置闪现,可以在后面的请求里拿到这个闪现的值。

    from flask import Flask, flash
    # 需要导入flash
    # 设置
    flash('aaa')
    # 取值
    get_flashed_message()
    # 设置
    flash('bbb',category='error1')
    # 取值
    res=get_flashed_messages(category_filter=['error1'])
    # 假设在a页面操作出错,跳转到b页面,在b页面显示a页面的错误信息
    

    注意如果闪现多个值,可以一次取出来,下次再取就取不到了(一次性的消息)

    请求扩展

    类似于django的中间件,请求来或者走的时候做点事情,也是基于装饰器实现的

    # 1 请求来了就会触发,类似于django的process_request,如果有多个,顺序是在文件中从上往下
    @app.before_request
    def before(*args,**kwargs):
        if request.path=='/login':
            return None
        else:
            name=session.get('user')
            if not name:
                return redirect('/login')
            else:
                return None
    # 2 # 请求走了就会触发,类似于django的process_response,如果有多个,顺序是从下往上执行
    @app.after_request
    def after(response):
        print('我走了')
        return response
    
    #3 before_first_request 项目启动起来第一次会走,以后都不会走了,也可以配多个(项目启动初始化的一些操作)
    @app.before_first_request
    def first():
        print('第一次')
        
    # 4 每次视图函数执行完了都会走它,# 用来记录出错日志
    @app.teardown_request  # 用来记录出错日志
    def ter(e):
        print(e)
        print('我是teardown_request ')
    
        
    # 5 errorhandler绑定错误的状态码,只要码匹配,就走它
    @app.errorhandler(404)
    def error_404(arg):
        return render_template('error.html',message='404错误')
    
    # 
    # 6 全局标签
    @app.template_global()
    def sb(a1, a2):
        return a1 + a2
    # 在模板中:{{ sb(3,4) }}
    
    # 7 全局过滤器
    @app.template_filter()
    def db(a1, a2, a3):
        return a1 + a2 + a3
    # 在模板中{{ 1|db(2,3)}}
    
    • 常用的就是 before_requestafter_request,
    • 注意有多个的情况,执行顺序
    • before_request请求拦截后(也就是有return值),response所有都执行
  • 相关阅读:
    TFS二次开发-基线文件管理器(5)-源码文件的读取
    TFS二次开发-基线文件管理器(4)-标签的创建
    TFS二次开发-基线文件管理器(3)-源码文件的读取
    TFS二次开发-基线文件管理器(2)-TFS登录
    TFS二次开发-基线文件管理器(1)-设计
    学习实践:使用模式,原则实现一个C++自动化测试程序
    学习实践:使用模式,原则实现一个C++数据库访问类
    C++字符转换等常用方法
    sqlserver 创建 aspstate的方法
    双网卡只有一个能ping通的解决办法
  • 原文地址:https://www.cnblogs.com/telecasterfanclub/p/13569717.html
Copyright © 2011-2022 走看看