Python Flask API 讲解与示例演示(附cookies和session)

2023-05-23 17:08:30 python flask 示例 讲解 演示

一、概述

Python Flask 是一个轻量级的 Web 框架,它提供了一个易于使用的 API 来创建 Web 应用程序。在 Flask 中,我们可以使用 Python 函数来定义 Web 应用程序的路由和处理程序。

二、常用函数讲解

以下是一些常见的 Python Flask API 函数:

1)Flask() 函数

这个函数是 Flask 应用程序的核心,用来创建一个新的 Flask 实例。

from flask import Flask

app = Flask(__name__)

2)route() 函数

这个函数用来指定路由和请求方法。可以使用多个 route() 函数来定义多个路由。

@app.route('/')
def hello_world():
return 'Hello, World!'

3)jsonify() 函数

这个函数可以将 Python 对象转换为 JSON 格式的响应对象。

from flask import jsonify

@app.route('/users')
def get_users():
users = [
{'name': 'Alice', 'age': 25},
{'name': 'Bob', 'age': 30},
{'name': 'Charlie', 'age': 35}
]
return jsonify(users)

4)render_template() 函数

这个函数用来渲染模板并返回 HTML 响应对象。可以使用模板引擎来动态生成 HTML。

from flask import render_template

@app.route('/profile/<username>')
def profile(username):
return render_template('profile.html', name=username)

5)redirect() 函数

这个函数可以将请求重定向到另一个 URL。

from flask import redirect

@app.route('/redirect')
def redirect_to_home():
return redirect('/')

6)url_for() 函数

这个函数用于生成 URL,可以使用视图函数的名称作为参数。

from flask import url_for

@app.route('/profile/<username>')
def profile(username):
return f'Hello, {username}! Your profile URL is {url_for("profile", username=username)}.'

7)before_request() 函数

这个函数用来注册一个函数,在每个请求之前执行。

@app.before_request
def before_request():
if 'user_id' not in session and request.endpoint not in ['login', 'static']:
return redirect(url_for('login'))

8)after_request() 函数

这个函数用来注册一个函数,在每个请求之后执行。

@app.after_request
def after_request(response):
response.headers['X-Frame-Options'] = 'SAMEORIGIN'
return response

9)abort() 函数

这个函数用于在视图函数中引发异常,并返回一个错误响应。

from flask import abort

@app.route('/users/<int:user_id>')
def get_user(user_id):
user = User.query.get(user_id)
if user is None:
abort(404)
return jsonify(user.to_dict())

10)send_file() 函数

这个函数用于发送文件作为响应,可以将文件作为字节流或者文件路径来发送。

from flask import send_file

@app.route('/download')
def download_file():
file_path = '/path/to/file'
return send_file(file_path, as_attachment=True)

三、常用对象讲解

1)request 对象

这个对象表示客户端发出的请求,包含请求头和请求体等信息。可以使用 request 对象来获取客户端发送的数据。

from flask import request

@app.route('/login', methods=['POST'])
def login():
username = request.form['username']
password = request.form['password']
return f'Hello, {username}! Your password is {password}.'

2)session 对象

这个对象可以用来存储用户会话数据,例如用户 ID 等。

from flask import session

@app.route('/login', methods=['POST'])
def login():
username = request.form['username']
password = request.form['password']
if username == 'admin' and password == 'password':
session['user_id'] = 1
return redirect('/')
else:
return 'Invalid username or password.'

四、Flask 中的 cookies 与 session

1)cookies 与 session 的介绍与区别

在 Flask 中,Cookies 和 Session 都是用来跟踪用户状态的机制。

  • Cookie 是一小段文本数据,当一个用户访问你的网站时,服务器可以通过设置 cookie 把一些数据存储在用户的计算机上。当用户再次访问网站时,浏览器会发送 cookie 数据给服务器,以便服务器可以使用该数据来识别用户。Flask 使用 Flask-Cookie 来处理 cookies,使用它可以设置、获取和删除 cookies

  • Session 是一种在服务器端存储的状态数据,与 Cookie 不同,Session 数据不会存储在用户的计算机上,而是存储在服务器端。当一个用户访问你的网站时,服务器会为该用户创建一个的 Session ID,并将该 ID 存储在一个 cookie 中,然后服务器使用该 Session ID 来识别用户。Flask 使用 Flask-Session 来处理 Session,使用它可以设置、获取和删除 Session 数据。

  • 一般来说,Session 更加安全,因为数据存储在服务器端,而且用户无法直接修改数据。Cookie 的优点是可以存储大量数据,并且可以在不同的页面之间共享。在实际使用中,开发者可以根据需要选择使用 Cookie 或 Session

以下是在 Flask 中使用 Cookies 和 Session 的示例:

2)示例讲解

1、使用 Flask-Cookie 设置 Cookie

from flask import Flask, make_response

app = Flask(__name__)

@app.route('/')
def index():
response = make_response('Hello, World!')
response.set_cookie('name', 'value')
return response

if __name__ == '__main__':
app.run()

在上面的例子中,我们使用 Flask 的 make_response 函数创建一个响应对象,然后使用 set_cookie 方法设置了一个名为 name,值为 value 的 cookie

2、使用 Flask-Cookie 获取 Cookie

from flask import Flask, request

app = Flask(__name__)

@app.route('/')
def index():
name = request.cookies.get('name')
return f'Hello, {name}!'

if __name__ == '__main__':
app.run()

在上面的例子中,我们使用 Flask 的 request 对象获取了名为 name 的 cookie 的值,然后将其返回给用户。

3、使用 Flask-Session 设置和获取 Session

from flask import Flask, session

app = Flask(__name__)
app.config['SECRET_KEY'] = 'your_secret_key'

@app.route('/')
def index():
session['name'] = 'value'
name = session.get('name')
return f'Hello, {name}!'

if __name__ == '__main__':
app.run()

在上面的例子中,我们使用 Flask 的 session 对象设置了一个名为 name,值为 value 的 Session,并使用 get 方法获取了该 Session 的值,然后将其返回给用户。

需要注意的是,为了使用 Flask-Session,需要在应用程序中设置一个 SECRET_KEY。该密钥用于加密 Session 数据,以确保数据不被篡改。


Python Flask 常用的API函数、类对象以及 cookies 和 session 的讲解与示例演示就先到这里了

相关文章