URL传参:

  • 良好的URL:视图函数对应的url以/结尾是一种良好url,因为用户在访问的时候无论他有没有加上最后这个斜杠,都是能访问到的,相反,视图函数的url没有以/结尾,用户访问的时候却加上了这个/,那么用户是访问不到这个网页的。
  • 使用path形式传参:使用尖括号,如“<value>”将参数“value”通过URL传入视图函数,在视图函数中也需要有同名的参数。如果URL中有多个参数,则视图函数中也需要按顺序定义相同的参数。这样可以使用相同URL,但是因为参数不同而加载的数据却不同。如图:
  • path传参中指定URL参数类型:在“<>”中使用形如“/args/<int:value>”来指定参数类型(此处指定的是int类型),注意冒号后面不能有空格,必须紧跟参数名。参数的常用数据类型有:
  • string:默认的类型,可以是任何不包含“/”和“”的文本。
  • int:整型。
  • float:浮点类型。
  • path:和string类似,区别在于path类型可以包含“/”,即path类型为一个路径表示文本。
  • uuid:uuid字符串。
  • any:url的同一个位置可以是多个值。例如下图中“/user/111”和“/author/222”两个不同URL都将使用同一个视图函数:
  • 自定义url参数类型:自定义的类型需要继承类BaseConverter,即from werkzeug.routing import BaseConverter,并且需要把这个类注册到app.url_map.converters中才会生效。有两种方式:
  • 第一种:在子类中重新定义变量regex,根据自身需要写正则表达式,这个正则表达式就是参数需要满足的条件和格式。
  • 第二种:在子类中重写to_pythonto_url方法,这两个方法的参数都只有一个,即value。to_python的value是url中传入的字符串,它的返回值会作为对应视图函数的参数值传入;而to_url是用作函数url_for的返回值的,它的参数value是url_for函数传入的参数值,参数的格式和类型则是to_python方法的返回值,to_url的返回值则会在填充到url字符串中对应参数的位置。
• 1 from flask import Flask, url_for
 2 from werkzeug.routing import BaseConverter
 3 
 4 app = Flask(__name__)
 5 
 6 
 7 class TelConverter(BaseConverter):
 8     """
 9     第一种方式:只重新定义变量regex的正则表达式
10     例如:该参数必须为11位的数字
11     """
12     regex = r'd{11}'
13 
14 
15 class PlusConverter(BaseConverter):
16     """
17     第二种方式:重写方法to_python和to_url,前者用于视图函数的参数获取,后者用于url_for的url字符串获取
18     例如:参数需要以+号来进行分割进行获取
19     """
20 
21     def to_python(self, value):
22         """例如传入的value为:python+27"""
23         return value.split('+')
24 
25     def to_url(self, value):
26         """例如传入的value为:['python', '27']"""
27         return '+'.join(value)
28 
29 
30 # 将自定义的参数类型进行注册,注册后才能生效
31 app.url_map.converters['tel'] = TelConverter
32 app.url_map.converters['plus'] = PlusConverter
33 
34 
35 @app.route('/')
36 def hello_world():
37     """
38     这里的url_for函数返回的则是:/python+27/
39     就是说返回的url字符串中的参数值是经过to_url方法处理后返回的
40     """
41     return url_for('get_plus', plus_args=['python', '27'])
42 
43 
44 @app.route('/<tel:telephone>/')
45 def get_telephone(telephone):
46     """此处的参数则被要求必须是11位的数字"""
47     return '你的手机号是:{}'.format(telephone)
48 
49 
50 @app.route('/<plus:plus_args>/')
51 def get_plus(plus_args):
52     """
53     如果访问:http://127.0.0.1:5000/python+27/
54     则plus_args的值为['python', '27']
55     也就是说传入的参数值是经过了to_python方法的处理返回的
56     """
57     return str(plus_args)
58 
59 
60 if __name__ == '__main__':
61     app.run(debug=True)
  • 使用查询字符串的方式传参:即在浏览器的URL中使用“?key=value”的形式传递参数(多个参数之间使用“&”连接即可),在后台则使用“from flask import request”,然后使用“request.args.get(key)”来获取参数key的值value。

URL请求:需要导入request对象“from flask import request”,提交的请求的相关信息都在这个对象中了。

  • 在route中指定视图函数的请求接收方式:指定参数如“methods=['GET', 'POST']”,methods参数的值是一个列表,在其中指定需要的请求方式即可,若没有指定则默认是GET,如果接收到的是POST请求,但却没有指定,则会报错。
  • get请求获取参数值:使用查询字符串的方式传递参数时,使用“request.args.get('param_name)')”即可。
  • post请求获取参数值:使用form表单传递参数时,使用“request.form.get('param_name')”即可,这个“param_name”是HTML中form表单元素的name属性的值,当然也需要在form中指定提交请求的方式为post“method="POST"”(特别注意在视图函数的route中也要指明post请求方式)。
  • 获取request请求方式:使用“request.method”即可,它的值为请求方式的全大写,比如“POST”。

URL重定向:需要“from flask import redirect”,它的第一个参数是一个URL字符串,这个URL字符串推荐使用“url_for”来获取,第二个参数可以指定HTTP状态码,默认是302(302表示暂时性重定向,301表示永久性重定向)。如图:

axios url后面跟参数 url中参数_axios url后面跟参数