史上超详细的Flask参数以及响应讲解

目录

Flask中参数的使用

请求方法

Request

函数返回内容

Response对象

字符串

返回Json


没有安装的在这里安装:Python+Flask安装

Flask中参数的使用

@app.route('/parames/<username>/')
def hello_world3(username, age=20):
    return username + ''

以上代表的是路径参数。

Flask中的参数:
1)都是关键字参数 
2)默认标识是<>
3)username需要和对应的视图函数的参数名字保持一致。
4)参数允许有默认值:
如果有默认值,那么在路由中,不传输参数也是可以的。
如果没有默认值,参数在路由中必修传递。
5)参数默认类型是string,如果想修改为其它类型,如下
<参数类型:username>

# 设置username为int类型
<int:username> 


参数语法

  • string 默认类型,会将斜线认为是参数分隔符
  • int 限制参数的类型是int类型
  • float 显示参数对的类型是float类型
  • path 接受到的数据格式是字符串,特性会将斜线认为是一个字符
@app.route('/usepath/<path:name>/', methods=['GET', 'POST'])
def use_path(name):
    return str(name)

userpath后面的路径随便写,如
http://192.168.100.95:8080/usepath/dfdsf/dsfsdf/fdsfds/
http://192.168.100.95:8080/usepath/dfdsf/

  • uuid  显示参数为uuid类型
@app.route('/getuuid/')
def get_uuid():
    # d01d1bd6-cb22-4d64-89d5-830928ba5842
    return str(uuid.uuid4())


@app.route('/useuuid/<uuid:name>/')
def use_uuid(name):
    print(name)
    return '获取到了uuid'

假如get_uuid生成的uuid为d01d1bd6-cb22-4d64-89d5-830928ba5842,那么调用use_uuid的样式如下:

http://192.168.100.95:8080/getuuid/d01d1bd6-cb22-4d64-89d5-830928ba5842/
  • any  任意一个,列出的元组中的任意一个,和枚举一个意思
@app.route('/any/<any(a,b,c):an>/')
def useany(an):
    return str(an)

使用any只能使用指定的参数,如上面只能用a,b,c,这三个参数。 

请求方法

常用的有5中,请求方式默认是GET,可以在路由中设置,如下

methods=['GET', 'POST','DELETE'.'PUT','HEAD']

Request

服务器在接收到客户端的请求后,会自动创建Request对象;
Request对象由Flask框架创建,Request对象不可修改。Request对象是代理对象

下面罗列部分Request的属性:

  • request:<Request 'http://192.168.100.95:8080/request/?username=zhangsan&password=123456' [GET]>
  • request.method:请求方法
  • type(request):<class 'werkzeug.local.LocalProxy'>
  • request.data: 这个是二进制的数据
  • request.args:获取get请求参数,ImmutableMultiDict([('username', 'zhangsan'), ('password', '123456')])
  • request.args['name'] &request.args.get('name'):获取get请求参数中key为name的value

上面两种获取get请求参数的区别: 第一个不传name会报错,

http://192.168.100.95:8080/request/           这个会报错

http://192.168.100.95:8080/request/?name=zhangsan   这个不会报错

而第二种不穿name不会报错,会返回None

  • request.form: post相关请求数据,打印的格式为 ImmutableMultiDict([('name', 'zhangsan')])
  • request.files:ImmutableMultiDict([('image', <FileStorage: 'timg.jpg' ('image/jpeg')>)])   image是key,timg.jpg是值。
  • request.url:获取url地址,如 http://192.168.100.95:8080/request/

 

函数返回内容

 

Response对象

可以制作一个响应进行返回make_response(str(data2)),也可以直接创建Response进行返回。

制作一个响应

result = make_response(str(data2))

make_response中的参数有3个

make_response(data,status,headers)

data:需要制作响应的数据。

status:响应的状态码。平时我们请求接口的时候,如果成功状态码是200,Flask中这个状态码可以修改,在反爬虫中涌出很大。如我将数据成功返回,而状态码是401,那么其他人爬虫的时候就不会爬这些数据。

headers:请求头。

除了制作一个响应,还可以直接使用Response对象:

jsondata = json.dumps({'status': '1', 'msg': '请求成功'})
result = Response(response=jsondata, content_type='application/json')

使用Response设置了返回的数据类型为Content-Type →application/json,也就是返回的是json数据。
这里通过Response将字符串转为application/json。

字符串

返回的如果是字符串会包装成Response对象

返回Json

json.jsonify将数据格式化为json格式,同时设置返回类型为Content-Type →application/json

json.jsonify有两种写法:

第一种直接返回json对象。

jsondata = json.jsonify({'status': '1', 'msg': '请求成功'})

第二种以key=value的形式返回:

jsondata = json.jsonify(status=1, msg='请求成功')

以上两种返回的结果都是一样的数据:

{
    "msg": "请求成功",
    "status": 1
}


json.dumps将数据格式化为json格式,没有设置返回类型,默认的类型为Content-Type →text/html; charset=utf-8

jsondata = json.dumps({'status': '1', 'msg': '请求成功'})

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值