用户id可以出现在url中吗_Python中Flask框架学习(4),你确定不进来看看?

今天学习Flask框架中正则匹配路由以及异常捕获;

正则匹配路由

在 web 开发中,可能会出现限制用户访问规则的场景,那么这个时候就需要用到正则匹配,根据自己的规则去限定请求参数再进行访问

具体实现步骤为:

  • 导入转换器基类:在 Flask 中,所有的路由的匹配规则都是使用转换器对象进行记录
  • 自定义转换器:自定义类继承于转换器基类
  • 添加转换器到默认的转换器字典中
  • 使用自定义转换器实现自定义匹配规则

代码实现

  • 导入转换器基类
from werkzeug.routing import BaseConverter
  • 自定义转换器
# 自定义正则转换器class RegexConverter(BaseConverter):    def __init__(self, url_map, *args):        super(RegexConverter, self).__init__(url_map)        # 将接受的第1个参数当作匹配规则进行保存        self.regex = args[0]
  • 添加转换器到默认的转换器字典中,并指定转换器使用时名字为: re
app = Flask(__name__)# 将自定义转换器添加到转换器字典中,并指定转换器使用时名字为: reapp.url_map.converters['re'] = RegexConverter
  • 使用转换器去实现自定义匹配规则当前此处定义的规则是:3位数字
@app.route('/user/')def user_info(user_id):    return "user_id 为 %s" % user_id

自定义转换器其他两个函数实现

继承于自定义转换器之后,还可以实现 to_python 和 to_url 这两个函数去对匹配参数做进一步处理:

  • to_python:该函数参数中的 value 值代表匹配到的值,可输出进行查看匹配完成之后,对匹配到的参数作最后一步处理再返回,比如:转成 int 类型的值再返回:
class RegexConverter(BaseConverter):    def __init__(self, url_map, *args):        super(RegexConverter, self).__init__(url_map)        # 将接受的第1个参数当作匹配规则进行保存        self.regex = args[0]    def to_python(self, value):        return int(value)

运行测试,在视图函数中可以查看参数的类型,由之前默认的 str 已变成 int 类型的值

  • to_url:在使用 url_for 去获取视图函数所对应的 url 的时候,会调用此方法对 url_for 后面传入的视图函数参数做进一步处理具体可参见 Flask 的 app.py 中写的示例代码:ListConverter

系统自带转换器

DEFAULT_CONVERTERS = {    'default':          UnicodeConverter,    'string':           UnicodeConverter,    'any':              AnyConverter,    'path':             PathConverter,    'int':              IntegerConverter,    'float':            FloatConverter,    'uuid':             UUIDConverter,}

系统自带的转换器具体使用方式在每种转换器的注释代码中有写,请留意每种转换器初始化的参数。

a31e8c84aae5fd18d9cb1f731445f4ae.png

异常捕获

HTTP 异常主动抛出

  • abort 方法抛出一个给定状态代码的 HTTPException 或者 指定响应,例如想要用一个页面未找到异常来终止请求,你可以调用 abort(404)。
  • 参数:code – HTTP的错误状态码
# abort(404)abort(500)

抛出状态码的话,只能抛出 HTTP 协议的错误状态码

捕获错误

  • errorhandler 装饰器注册一个错误处理程序,当程序抛出指定错误状态码的时候,就会调用该装饰器所装饰的方法
  • 参数:code_or_exception – HTTP的错误状态码或指定异常
  • 例如统一处理状态码为500的错误给用户友好的提示:
@app.errorhandler(500)def internal_server_error(e):    return '服务器搬家了'
  • 捕获指定异常
@app.errorhandler(ZeroDivisionError)def zero_division_error(e):    return '除数不能为0'

事在人为,努力就有收获,每天前进一小步,一年下来就是跨了一大步,每天分享给大家的知识没时间看要记得收藏下来哦,多做知识积累,总有一天会派上用场。

b73e91503e2175685b4293a98ad1eaeb.png
Flask 框架实现服务器推送可以使用 WebSocket 技术。WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,可以实现服务器向客户端推送消息。 以下是一个示例代码,演示了如何在 Flask 实现服务器推送: ```python from flask import Flask, render_template from flask_socketio import SocketIO, emit app = Flask(__name__) app.config['SECRET_KEY'] = 'secret!' socketio = SocketIO(app) @app.route('/') def index(): return render_template('index.html') @socketio.on('connect') def test_connect(): print('Client connected') @socketio.on('disconnect') def test_disconnect(): print('Client disconnected') if __name__ == '__main__': socketio.run(app) ``` 在这个示例,我们使用 Flask-SocketIO 扩展来实现 WebSocket 功能。当客户端连接到服务器时,Flask-SocketIO 会自动触发 `connect` 事件,当客户端断开连接时,会触发 `disconnect` 事件。 你可以通过 `emit` 方法来向客户端发送消息。例如,以下代码演示了如何在服务器端发送消息给客户端: ```python @socketio.on('my_event') def handle_my_custom_event(json): print('received json: ' + str(json)) emit('my_response', json) ``` 在这个示例,我们定义了一个名为 `my_event` 的事件。当客户端触发该事件时,服务器会打印接收到的 JSON 数据,并使用 `emit` 方法将数据再次发送回客户端,这次使用了 `my_response` 事件名。 你可以在客户端代码使用 JavaScript 来监听这些事件,并处理服务器发送的数据。例如,以下代码演示了如何在客户端使用 JavaScript 监听 `my_response` 事件: ```javascript var socket = io.connect('http://localhost:5000'); socket.on('my_response', function(data) { console.log(data); }); ``` 在这个示例,我们使用 `io.connect` 方法连接到服务器,并使用 `socket.on` 方法监听名为 `my_response` 的事件。当服务器发送该事件时,客户端会将数据打印到控制台。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值