flask中的response

1、Response

在flask中你想向前端返回数据,必须是Response的对象,这里和django必须是HttpResponse 对象一样, 主要将返回数据的几种方式

  1. 视图函数中return 字符串

    from flask import Flask
    
    app = Flask(__name__)
    
    @app.route("/index")
    def index():
     return "index.html"
    
    if __name__ == "__main__":
     app.run()
  2. return 多个值
    @app.route("/page_one")
    def page_one():
        return "index.html", "200 Ok", {"name": "aaa"}
    

    return后面的值说明:index.html 表示字符串,也就是网站页面显示的内容

    ? ‘200 ok‘ 表示状态码和对状态码的解析

    ? {"name":"aaa"} 表示请求头

    请求头不是必须要的,但是前面两个必须要,前提你是retrun多个值,还有就是顺序不能改变。

  3. return make_response
    @app.route("/page_two")
    def page_two():
        response = make_response('page_two page', 200)
        response.headers["name"] = "page_four"
        return response
    
    @app.route("/page_three")
    def page_three():
        response = make_response('page_three page')
        return response, 200, {"name": "page_three"}
    
    @app.route("/page_four")
    def page_four():
        response = make_response('page_four page', 200, {"name": "page four"})
        return response

    分析下上面的三种方法,都是能够成功返回的。总结下

    make_response 它可以传递三个参数 第一个还是一个字符串,第二个传状态码,第三个传请求头,

    关于return 还是和 return 多个值分析差不多,只不过第一个参数不是字符串,而是一个对象了。

  4. return Response对象
    from flask import Response
    
    @app.route("/page_five")
    def page_five():
        response = Response("page five")
        response.status_code = 299
        response.status = "298 notok"
        return response, "297 okok", {"name": "page fiv"}

总结:

  1. 视图函数可以返回一个元组(也就是多个值),返回多个值的话,必须注意顺序,第一位必须为字符串或者Response对象,第二个参数应该为状态码,第三个参数就是请求头里的数据了
  2. 如果返回一个值的话,那么就是一个字符串,或者就是Response对象
  3. 还有就是make_response这个函数的返回值应该也是Response的对象,额额,刚刚打印了type(make_response()) 结果为 flask.wrappers.Response ,确实是Response的对象。

render_template : 导入方式 from flask import render_template

def render_template(template_name_or_list, **context):
    pass

它的作用就是模板渲染,最终返回html渲染好了的字符串,它需要传递的参数就是 模板的名字,也就是需要渲染的html页面,还有就是这样格式的数据:key1 = value1,key2=value2这样的格式,传这些变量到模板中,肯定是渲染变量用。

redirect :导入方式 from flask import redirect

def redirect(location, code=302, Response=None):
    pass

它的作用就是重定向,需要传的参数就是重定向的地址,最终返回的Response的对象

2、Response中的几个属性

  1. headers : 设置请求头信息
  2. status : String类型的数据,格式为这种:"200 ok"
  3. status_code : int 类型,就是状态码,但是不能是自定义的状态码
  4. data : 需要返回到前端的数据
  5. set_cookie :设置cookie 的值
  6. del_cookie :删除cookie ,不会立马删除浏览器上报错的cookie 值,会讲过期时间设置为当前时间,还是cookie 创建的时间,这样就表示过期了,浏览器会自动删除。

3、写一个登陆成功设置cookie的例子

from flask import Flask, request, Response

app = Flask(__name__)

@app.route('/login', methods=["get", "post"], endpoint='login')
def login():
    if request.method == "POST":
        response = Response()
        name = request.form.get("name")
        pwd = request.form.get("pwd")
        if name and pwd:
            if name == '朱宇' and pwd == '123':
                response.data = '登陆成功'
                # 注意,我这里只是写个例子,不会拿明文的账号密码设置为cookie
                response.set_cookie('name', '朱宇')
                response.set_cookie('pwd', '123')
            else:
                response.data = '用户名或密码错误'
        else:
            response.data = '用户名或密码不能为空'
        return response
    elif request.method == 'GET':
        # 我这里返回字符串表示一个页面,你完全可以写一个html页面,使用render_template这个方法返回
        return 'login.html'

if __name__ == "__main__":
    app.run(debug=True)

下面我用postman做下测试,

再看上面红色狂圈住的地方,这就是我们设置的两个cookies,鼠标点进去看

你们有这样的疑问的吗?我最终还是返回的Response的对象,那么浏览器是怎么知道我对cookie进行操作呢?

答案在这里,就是响应的请求头,看看返回了哪些数据

Response 的介绍大概就是这样,还有其他属性请参考flask官方API

原文地址:https://www.cnblogs.com/zhuchunyu/p/10466509.html

时间: 2024-10-30 06:52:44

flask中的response的相关文章

通过FLASK中的RESPONSE返回JSON数据

使用flask的过程中,发现有时需要生成一个Response并返回.网上查了查,看了看源码,找到了两种办法: from flask import Response, json Response(json.dumps({'a': 1, 'b':1}),content_type='application/json') 更简单的方法是: from flask import jsonify jsonify({'a': 1, 'b': 2}) 本质上,两者是一样的.Werkzeug相关说明在这里. 当然,

Flask中的request与response

Flask中的request from flask import Flask,request app = Flask(__name__) @app.route("/",methods=["POST","GET"]) def index(): # 请求相关的信息 print("请求方法",request.method)#请求方法 print("get请求的参数",request.args)# get请求的参数

Flask中全局变量的实现

我们都知道在Flask中g,request,session和request是作为全局对象来提供信息的,既然是全局的又如何保持线程安全呢,接下来我们就看看flask是如何做到这点的.在源码中的ctx.py中有AppContext和RequestContext两个类,他们分别管理应用上下文和请求上下文.两者的实现也差不多,这里我们看看AppContext的实现 class AppContext(object): """The application context binds a

Flask中的session ,自定义实现 session机制, 和 flask-session组件

session 是基于cookie实现, 保存在服务端的键值对(形式为 {随机字符串:‘xxxxxx’}), 同时在浏览器中的cookie中也对应一相同的随机字符串,用来再次请求的 时候验证: 注意 :Flask中的session是存在浏览器中 默认key是session(加密的cookie), 也可以像Django一样基于上述的方式实现保存在数据库 1 flask中 session的基本概念 flask 有一个 session 对象.它允许你在不同请求间存储特定用户的信息.它是在 Cookie

flask 中的ORM

1 响应(response) 1 什么是响应 响应就是由服务器端带给客户端的内容,对应着请求,响应可以是普通的字符串,模板 或重定向 return '普通字符串' return render_template('xxx.html') 2 响应对象 响应对象:将响应的内容封装到一个对象中,可以完成更多的响应的行为(如:增加cookies,..) 在Flask中,使用 make_response() 构建响应对象 2 文件上传 1 注意问题 表单中如果有文件上传的话,必须遵循以下两个要求 1 提交方

Flask中使用cookie和session

Flask中使用cookie和session 设置cookie from flask import Flask,Response app = Flask(__name__) @app.route('/index') def index(): response = Response("设置cookie") response.set_cookie('username','sfencs') return response if __name__ == '__main__': app.run(

Flask中session实现原理

前言 flask_session是flask框架实现session功能的一个插件,用来替代flask自带的session实现机制,flask默认的session信息保存在cookie中,不够安全和灵活. flask的session机制 session是用来干什么的呢?由于http协议是一个无状态的协议,也就是说同一个用户第一次请求和第二次请求是完全没有关系的,但是现在的网站基本上有登录使用的功能,这就要求必须实现有状态,而session机制实现的就是这个功能. 实现的原理: 用户第一次请求后,将

Flask中使用mysql

Flask中使用mysql 先安装相关模块: pip  install  Flask-MySQL 先准备一下数据库 登录: mysql  -u  root  -p 创建Database和创建Table mysql> CREATE DATABASE EmpData; mysql> use EmpData; mysql> CREATE TABLE User( userId INT NOT NULL AUTO_INCREMENT, userName VARCHAR(100) NOT NULL,

flask中'bool' object has no attribute '__call__'问题

#写flask时报错 <ul class="nav navbar-nav"> <li><a href="/">Home</a></li> </ul> </div> <ul class="nav navbar-nav navbar-right"> {% if current_user.is_authenticated() %} <li><