flask-基础篇02 请求与响应
一、处理请求
1、URL路径参数(动态路由)
# 例如,有一个请求访问的接口地址为/users/123,其中123实际上为具体的请求参数,表明请求123号用户的信息。此时如何从url中提取出123的数据?
@app.route("/user/<user_id>")
def user_info(user_id):
print(user_id)
return "hello user {}".format(user_id)
# 上面<>是一个转换器,默认为字符串类型,即将该位置的数据以字符串格式进行匹配、并以字符串为数据类型、user_id 为参数名传视图。
2、Flask提供的其他的转换器
DEFAULT_CONVERTERS = {
'default': UnicodeConverter,
'string': UnicodeConverter,
'any': AnyConverter,
'path': PathConverter,
'int': IntegerConverter,
'float': FloatConverter,
'uuid': UUIDConverter,
}
将上面的例子以整形匹配数据,可以如下使用:
@app.route('/user/<int:user_id>')
def user_info(user_id):
print(type(user_id))
return "hello world {}".format(user_id)
3、自定义转换器
问题:如果遇到需要匹配提取 /sms_codes/13886555555 中的手机号数据,Flask内置的转换器将无法满足,此时需要自定义转换器。
定义方法(分为三步)
# 第一步、创建转换器类,保存匹配的正则表达式
from werkzeug.routing import BaseConverter class MobileConverter(BaseConverter):
"""
手机号码格式
"""
regex = r"1[3-9]\d{9}" # 注意 regex 名字是固定的 # 第二步、将自定义的转换器告知Flask应用
app = Flask(__name__) # 将自定义转换器添加到转换器字典中,并指定转换器使用时名字为:mobile
app.url_map.converters["mobile"] = MobileConverter # 第三步、在使用转换器的地方定义使用
@app.route('/sms_codes/<mobile:mob_num>')
def send_sms_code(mob_num):
return "send sms code to {}".format(mob_num)
4、其他参数
如果想要获取其他地方传递的参数,可以通过Flask提供的 request 对象来读取。
不同位置的参数都存放在request的不同属性中
| 属性 | 说明 | 类型 |
|---|---|---|
| data | 记录请求的数据,并转换为字符串 | * |
| form | 记录请求中的表单数据 | MultiDict |
| args | 记录请求中的查询参数 | MultiDict |
| cookies | 记录请求中的cookie信息 | Dict |
| headers | 记录请求中的报文头 | EnvironHeaders |
| method | 记录请求使用的HTTP方法 | GET/POST |
| url | 记录请求的URL地址 | string |
| files | 记录请求上传的文件 | * |
5、例如 想要获取请求 /articles??channel_id=1 中 channel_id 的参数,可以按如下方式使用:
from flask import request
@app.route('/reticles')
def get_reticles():
channel_id = request.args.get("channel_id")
return 'you wanna get articles of channel {}'.format(channel_id)
6、上传图片
客户端上传图片到服务器,并保存到服务器中
from flask import request
@app.route('/upload', methods=['POST'])
def upload_file():
f = request.files["pic"] # 图片的键是 pic
# with open("./demo.png", "wb") as new_file:
# new_file.write(f.read())
f.save(./demo.png)
return "ok"
二、处理响应
需求:如何在不同的场景里返回不同的响应信息?
1、返回模板
使用 render_template 方法渲染模板并返回,例如下,新建一个模板 index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
我的模板html内容
<br/>{{ my_str }}
<br/>{{ my_int }}
</body>
</html>
后端视图
from flask import render_template
@app.route("/")
def index():
mstr = "Hello World"
mint = 10
render render_template("index.html", my_str=mstr, my_int=mint)
# 如果是一个字典,也可以这样
@app.route("/")
def index():
my_info = {
"mstr":"Hello World"
"mint":10}
render render_template("index.html", **my_info)
2、重定向
# 将一个路由重定向到百度首页
from flask import redirect @app.route("/demo2")
def demo2():
return redirect("http://www.baidu.com")
3、返回json
from flask import jsonify
@app.route("/demo3")
def demo3():
json_dict = {
"user_id": 10,
"user_name": "huofei"
}
return jsonify(json_dict)
4、自定义状态码和响应头
①元祖方式
可以返回一个元组,这样的元组必须是(request, status, headers)的形式,且至少包含一个元素。status 值会覆盖状态代码,headers可以是一个列表 或字典,作为额外的消息头值,实现代码如下:
@app.route("/demo4")
def demo4():
# return '状态为 666', 666
# return "状态码为 666", 666, [("name", "huofei")]
return "状态吗为 666", 666, {"name": "huofei"}
②make_response方式
@app.route("/demo5")
def demo5():
resp = make_response("make response测试")
resp.headers["name"] = "huofei"
resp.status = "404 not found"
return resp
三、Cookie
如何设置?如下代码:
from flask import Flask, make_response
app = Flask(__name__)
@app.route("/cookie")
def set_cookie():
resp = make_response("set cookie ok")
resp.set_cookie("username", "huofei")
return resp
设置有效期
@app.route("/cookie")
def set_cookie():
response = make_response('hello world')
# 设置有效期为3600秒
response.set_cookie("username", "huofei", max_age=3600)
return response
读取
from flask import request
@app.route("/get_cookie")
def get_cookie():
resp = request.cookie.get("username")
return resp
删除
# 删除的原理是将cookie的有效期修改为1970年了
from flask import request @app.route("/delete_cookie")
def delete_cookie():
response = make_response("hello world")
response.delete_cookie("username")
return response
四、Session
1、需要先设置SECRET_KEY,如下
class DefaultConfig(object):
SECRET_KEY = "fq3rfdsqdsaDFAdDAF" app.config.from_object(DefaultConfig) # 或者直接设置
app.secret_key = "abc1dsfq23321adaaf"
2、设置
from flask import session
@app.route("/set_session")
def set_session():
session["username"] = "huofei"
return "set session Ok"
3、读取
@app.route("/get_session")
def get_session():
username = session.get("username")
return "get session username {}".format(username)
flask-基础篇02 请求与响应的更多相关文章
- 第一篇 Flask基础篇之(配置文件,路由系统,模板,请求响应,session&cookie)
Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后 ...
- Java多线程系列--“基础篇”02之 常用的实现多线程的两种方式
概要 本章,我们学习“常用的实现多线程的2种方式”:Thread 和 Runnable.之所以说是常用的,是因为通过还可以通过java.util.concurrent包中的线程池来实现多线程.关于线程 ...
- WebBug靶场基础篇 — 02
本篇以第一人称记录这个关卡的第 1-5 关. 由于我记录的过程有点偏向于思考,所以截图截的多 = =!所以文章有点长... 下午一觉醒来,已经 4 点多了,然后开电脑,在虚拟机里,铺了铺靶场,但是毕竟 ...
- 【matlab 基础篇 02】基础知识一键扫盲,看完即可无障碍编程(超详细+图文并茂)
博主快速入门matlab,系统地整理一遍,如何你和我一样是一个新手,那么此文很适合你: 本人能力有限,文中难免有错误和纰漏之处,请大佬们不吝赐教 创作不易,如果本文帮到了您: 请帮忙点个赞
- 第二篇 Flask基础篇之(闪现,蓝图,请求扩展,中间件)
本篇主要内容: 闪现 请求扩展 中间件 蓝图 写装饰器,常用 functools模块,帮助设置函数的元信息 import functools def wrapper(func): @functools ...
- iOS系列 基础篇 02 StoryBoard 故事板文件
iOS基础 02 StoryBoard 故事板文件 目录: 1. 故事板的导航特点 2. 故事板中的Scene和Segue 3. 本文最后 在上篇HelloWorld工程中有一个Main.storyb ...
- JavaWeb基础-Jsp的请求与响应
JSP请求和相应 HTTP头信息 当浏览器请求一个网页时,它会向网络服务器发送一系列不能被直接读取的信息,因为这些信息是作为HTTP信息头的一部分来传送的. HttpServletRequest类 r ...
- python框架之Flask基础篇(一)
一.第一个hello world程序 # coding=utf-8 from flask import Flask app = Flask(__name__) @app.route('/') def ...
- MySQL基础篇(02):从五个维度出发,审视表结构设计
本文源码:GitHub·点这里 || GitEE·点这里 一.数据场景 1.表结构简介 任何工具类的东西都是为了解决某个场景下的问题,比如Redis缓存系统热点数据,ClickHouse解决海量数据的 ...
- Java岗 面试考点精讲(基础篇02期)
1. 两个对象的hashCode相同,则equals也一定为true,对吗? 不对,答案见下面的代码: @Override public int hashCode() { return 1; } 两个 ...
随机推荐
- “初始化 Java 工具”期间发生了内部错误, java.lang.NullPointerException
今天刚打开eclipse就报了这个错误,我怀疑是昨晚想关电脑的时候,关闭eclipse太快,没有等待工作空间保存就关了电脑的缘故 错误如图: (图片来自下方链接博客,因为忘记截图了) 我百度后按照提示 ...
- HCIP-ICT实战进阶05-路由策略与策略路由
HCIP-ICT实战进阶05-路由策略与策略路由 0 前言 什么是路由策略? 基于报文的目的IP地址进行路由表查找, 之后转发数据; 针对控制平面, 为路由协议和路由表服务, 针对路由信息进行过滤或者 ...
- 对SQL CTE的一点个人理解
/*执行顺序: 首先,执行按一.二,此时二输出的结果,可以理解为临时n 然后,按三.二.三.二循环执行 注意:,步骤三的where为递归终止条件,由于用的是substr函数.在最后一次递归的时候,如果 ...
- SignalR+Redis,SignalR+Sqlserver集群部署应对海量链接
一:SignalR+Sqlserver 1:新建一个MVC的空项目和之前一样 2:index页面的js代码如下 <script src="~/Scripts/jquery-1.10.2 ...
- C#开发上位机常用
从深圳回内地几年了,突然想把之前项目中用到的东西做信合集,别忘记了!!!
- (0617 ) centos7运行脚本提示: 没有那个文件或目录 :No such file or directory
https://blog.csdn.net/hehuihh/article/details/88174007 之前也 遇到: https://www.cnblogs.com/fancy2333/p/1 ...
- 一些sql查询的case
1.单列去重,输出去重后条目数量 select count(distinct(`id`)) from student; 2.根据分数段统计数据条目:利用case when selectcount(ca ...
- Camstar获取回参
public static bool SplitQty(string Username, string Password, string Container, int splitQty,int pla ...
- c# reflect里面的getValue()参数
Type ty = t.GetType(); PropertyInfo[] PropertyInfo = ty.GetProperties(); string Typename = typeof(T) ...
- 小程序Excel导入导出数据库功能
https://blog.csdn.net/yhcad/article/details/116204444 unit Umain;interfaceuses Winapi.Windows, Wina ...