今天接着上一篇继续写一篇关于flask的随笔。

本文大纲:

1、获取请求参数

2、一个函数处理多个请求方式

3、重定向

4、错误响应

5、全局错误处理

6、返回json格式数据

7、自定义返回内容状态码

一、request获取请求参数

from flask import Flask, request

app = Flask(__name__)

@app.route("/")
def index():
a = request
#get请求
get_data = request.args
#form 表单
form_data = request.form
#json header{application/json}
json_data = request.json
#file
file_data = request.files
#同时获取args和form
data = request.value
method = request.method
return a if __name__ == '__main__':
app.run(debug=True)

二、一个函数处理多个请求方式

只需要在app.route()中定义method访问方式,并且在函数中进行相应的处理即可

@app.route("/all_projects", methods=["GET", "POST"])
def all_projects():
if request.method == "GET":
return "get"
elif request.method == "POST":
return "post"

三、redirect重定向

redirect()中传入一个参数就可以实现重定向,那就是传入url,在实际操作中我们一般会使用url_for这个方法,传入端点即可。

端点:Url和视图函数的绑定关系,默认路由的名称,也就是这个路径绑定的函数名,可以在app.route()中传入endpoint关键字参数进行自定义端点名称。

from flask import Flask,redirect, url_for
app = Flask(__name__)
@app.route("/")
def index():
if request.args.get("username") is None:
return redirect("/login")
return redirect(url_for('login'))
return "hello"
@app.route("/login")
def login():
return "login"
#后面加参数,请求的时候会自动带上这个参数
return redirect(url_for('login', username="baijiahei"))

四、错误响应abort()

在一些我们可以预知的错误请求时,可以手动给出异常响应,使用时在abort()传入响应码即可,逻辑运行到这里会自动中断,在abort()中自定义了很多错误响应只需要传入响应码,就可以直接使用

@app.route("/")
def index():
if request.args.get("username") is None:
abort(401))
return "hello"

五、全局错误处理

有一些我们不可预知的错误,比如404,500(服务器正在维护)等情况,我们需要对用户给出友好提示,需要做全局错误处理

@app.errorhandler(500)
def server_error(error):
return render_template("error_500.html")

使用app.errorhandler() 传入响应状态码,当出现这个错误时,会执行下方函数,在函数中我们需要一个参数来接受错误信息。

注意:当我们定义了@app.errorhandler()之后,使用abort()时传入的响应码如果已经被定义了,则会调用,而不会继续使用abort()内置方法

六、返回json类型数据

这里使用了flask中的jsonify

当我们使用了jsonify时,返回的 Content-Type: application/json,使用方法很简单传入一个json格式的数据即可

from flask import Flask, jsonify

import json

app = Flask(__name__)

@app.route("/login")
def login():
return jsonify(json.dumps({"code": "1"}))

七、自定义返回内容状态码

from flask import Flask, make_response, jsonify

app = Flask(__name__)

@app.route("/")
def index():
# 构造一个响应头信息 返回值, 响应码, 响应头信息{},放在字典中 状态码或者响应头可以单个不加
# return json.dumps({"username": "白加黑"}), 201, {"content-type": "application/json"}
# make_response 第二种形式 r response()
# r = make_response(json.dumps({"username": "白加黑"}), {"content-type": "application/json"})
# r.status = "203"
# r.content_type = "text/plain"
# r.headers =
# r.content_type =
# r.mimetype =
r = jsonify({"username": "白加黑"})
# 修改状态码
r.status = "202"
return r

Python之Flask框架二的更多相关文章

  1. python之Flask框架

    一.简单的Flask框架 1)flask简介 Flask 是一个 web 框架.也就是说 Flask 为你提供工具,库和技术来允许你构建一个 web 应用程序. 这个 wdb 应用程序可以使一些 we ...

  2. Python基于Flask框架配置依赖包信息的项目迁移部署小技巧

    一般在本机上完成基于Flask框架的代码编写后,如果有接口或者数据操作方面需求需要把代码部署到指定服务器上. 一般情况下,使用Flask框架开发者大多数都是选择Python虚拟环境来运行项目,不同的虚 ...

  3. 使用Python的Flask框架,结合Highchart,动态渲染图表(Ajax 请求数据接口)

    参考链接:https://www.highcharts.com.cn/docs/ajax 参考链接中的示例代码是使用php写的,这里改用python写. 需要注意的地方: 1.接口返回的数据格式,这个 ...

  4. Python的Flask框架入门-Ubuntu

    全文请见tuts code:An Introduction to Python's Flask Framework Flask是Python一个小而强大的web框架.学起来简单,用起来也容易,能够帮你 ...

  5. Python之Flask框架项目Demo入门

    Python+Flask框架项目Demo入门 本例子用到了 Flask+蓝图+Flask-Login+SQLAlchemy+WTForms+PyMySQL相关架构 Flask Web框架介绍 Flas ...

  6. [Python WEB开发] 使用WSGI开发类Flask框架 (二)

    WSGI     Web服务器网关接口 WSGI主要规定了Web服务器如何与Web应用程序进行通信,以及如何将Web应用程序链接在一起来处理一个请求. wsgiref Python中的WSGI参考模块 ...

  7. [Python自学] Flask框架 (1) (Flask介绍、配置、Session、路由、请求和响应、Jinjia2模板语言、视图装饰器)

    oldboy:s9day114 参考博客:https://www.cnblogs.com/wupeiqi/articles/7552008.html 一.Flask简介 1.安装Flask pip i ...

  8. Python之Flask框架一

    flask是一个使用 Python 编写的轻量级 Web 应用框架.轻巧页就意味着他比较简洁,不过见到的MTV框架还是有的,(MVC)但是最重要的还是他的可扩展性很强,对比与Django框架呢,他的灵 ...

  9. 教你分分钟搞定Python之Flask框架

    用最短的时间开发一个数据操作接口,Python是王道! 一.安装pip .首先检查linux有没有安装python-pip包,终端执行 pip -V [root@ network-scripts]# ...

随机推荐

  1. CSS像素与绝对像素

    之前在电视的webview上投放广告页面时,遇到了个问题,就是视窗大小和文档大小不一致.最后发现原来有CSS Pixel这个概念,搜集了一些资料,希望能把这个问题捋捋清楚. 首先提出一个大家常常会忽略 ...

  2. css实现双色饼图

    from:wx--前端早读课 首先回想用css画三角形的方法: <div class="triangle"></div> .triangle { displ ...

  3. XShell 评估到期

    刚刚打开XShell弹出”评估到期“,点击确定后自动打开中文官网,得购买后才能使用. 当初下载的时候没留意到会有这一天.. 手头拮据的朋友可以通过下面方法绕过: 删除XShell. 到英文官网下载页找 ...

  4. React:Composition

    在日常的UI构建中,经常会遇到一种情况:组件本身更多是作为一个容器,它所包含的内容可能是动态的.未预先定义的.这时候它的内容取决另一个组件或外部的输入.比如弹层. props.children: Re ...

  5. vue 细节注意

    *只有vm.$data这些被代理的属性是响应的,能够重新渲染视图 *注意,不要在实例属性或者回调函数中(如 vm.$watch('a', newVal => this.myMethod()))使 ...

  6. JDBC基本使用方法

    JDBC基本使用方法 JDBC固定步骤: 加载驱动 String url="jdbc:mysql://localhost:3306/jdbcstudy?useUnicode=true& ...

  7. scrapy五大核心组件

    scrapy五大核心组件 引擎(Scrapy)用来处理整个系统的数据流处理, 触发事务(框架核心) 调度器(Scheduler)用来接受引擎发过来的请求, 压入队列中, 并在引擎再次请求的时候返回. ...

  8. python3.x 基础四:json与pickple

    每次打开一个文件,只dump1次 json.dump(dump的内容,文件句柄) json.load(文件句柄) json可以处理列表/字典/字符串等简单数据类型,但是不能处理复杂的数据类型,如函数的 ...

  9. 【1-n】区间覆盖 TOJ4168+BZOJ1192

    Xiao Ming is very interesting for array. He given a sorted positive integer array and an integer n. ...

  10. (一) Vue在创建的时候 入口文件 及相关的路由配置(及子路由配置)

    1. 首先明确一点  在书写之前尽量保持相关的文件知道含义 比如 components 啥的 知道是要放什么东西 在这里介绍一下   由于 vue 不是系统学习 所以很多的创建方式可能不一样  就是有 ...