06、flask---自定义URL

一、正则表达式中常见的基本符号

1.点号“.”

    一个点号可以代替除了换行符(\n)以外的任何一个字符,包括但不限于英文字母、数字、汉字、英文标点符号和中文标点符号。

2.星号“*”

    一个星号可以表示它前面的一个子表达式(普通字符、另一个或几个正则表达式符号)0次到无限次

3.问号“?”

    问号表示它前面的子表达式0次或者1次。注意,这里的问号是英文问号。

4.反斜杠“\”

    反斜杠在正则表达式里面不能单独使用,甚至在整个Python里都不能单独使用。反斜杠需要和其他的字符配合使用来把特殊符号变成普通符号,把普通符号变成特殊符号。如:“\n”。

5.数字“\d”

    正则表达式里面使用“\d”来表示一位数字。再次强调一下,“\d”虽然是由反斜杠和字母d构成的,但是要把“\d”看成一个正则表达式符号整体。

6.小括号“()”

小括号可以把括号里面的内容提取出来。

7.字符集[]  

一个字符的集合,可匹配其中任意一个字符

二、自定义URL

1.我们需要导入BaseConverter,BaseConverter中定义了int、string、float等常用的类型。

from werkzeug.routing import BaseConverter

2.我们可以根据BaseConverter中定义的int类型的形式,照葫芦画瓢,定义自己的需要的URL规则。我们定义一个电话号码匹配的URL规则类

# 一个url中,含有手机号码的变量,必须限定这个变量的字符串格式满足手机号码的格式
class TelephoneConveter(BaseConverter):
    regex = r'1[857342]\d{9}'

Notes:

1、自定义的URL必须继承BaseConverter类。

2.电话号码第一个是1,第二位是857342中的一个数字,其他九位只要是数字就OK了。

3、实现自定义URL的使用和自定义类型tel

app.url_map.converters['tel'] = TelephoneConveter

notes:

1.我们不是在routing.py中定义的类,所以必须要使用app.url_map.converters来实现键值对。

等价于系统默认的

2.以后我们只要用“tel”就表示电话号码的URL规则,和使用int、float、string一样。

@app.route('/telephone/<tel:my_tel>/')
def my_tel(my_tel):
    return '您的手机号码是:%s' % my_tel

完整的代码如下:

from flask import Flask,url_for
from werkzeug.routing import BaseConverter


app = Flask(__name__)

# 一个url中,含有手机号码的变量,必须限定这个变量的字符串格式满足手机号码的格式
class TelephoneConveter(BaseConverter):
    regex = r'1[85734]\d{9}'

app.url_map.converters['tel'] = TelephoneConveter


@app.route('/telephone/<tel:my_tel>/')
def my_tel(my_tel):
    return '您的手机号码是:%s' % my_tel


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

例子:访问posts版块下a版块和b版块所有的内容

# 用户在访问/posts/a+b/
class ListConverter(BaseConverter):
    def to_python(self, value):
        return value.split('+')

    def to_url(self, value):
        return "+".join(value)
        # return "hello"

app.url_map.converters['list'] = ListConverter

Notes:
1、`to_python`的作用:
这个方法的返回值,将会传递到view函数中作为参数。

@app.route('/posts/<list:boards>/')
def posts(boards):
    print(boards)
    return "您提交的板块是:%s" % boards

 

2、`to_url`的作用:
这个方法的返回值,将会在调用url_for函数的时候生成符合要求的URL形式。

@app.route('/')
def hello_world():
    print(url_for('posts',boards=['a','b']))
    return 'Hello World!'

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以参考以下代码: ```python from flask import Flask, redirect, url_for from flask_admin import Admin, AdminIndexView from flask_admin.contrib.sqla import ModelView from flask_login import current_user, LoginManager, login_user, UserMixin, logout_user app = Flask(__name__) app.config['SECRET_KEY'] = 'secret_key' login_manager = LoginManager() login_manager.init_app(app) # 定义一个 User 类,用于记录用户信息 class User(UserMixin): def __init__(self, user_id): self.id = user_id # 登录视图,处理用户登录请求 @app.route('/login', methods=['GET', 'POST']) def login(): if current_user.is_authenticated: return redirect(url_for('admin.index')) # 处理用户提交的表单 if request.method == 'POST': user_id = request.form['user_id'] password = request.form['password'] # 验证用户身份 if user_id == 'admin' and password == 'password': user = User(user_id) login_user(user) return redirect(url_for('admin.index')) # 显示登录表单 return render_template('login.html') # 登出视图,处理用户登出请求 @app.route('/logout') def logout(): logout_user() return redirect(url_for('login')) # 继承 AdminIndexView,实现自定义首页 class MyAdminIndexView(AdminIndexView): def is_accessible(self): return current_user.is_authenticated def inaccessible_callback(self, name, **kwargs): return redirect(url_for('login')) # 定义一个简单的数据模型 class User(db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(80), nullable=False) email = db.Column(db.String(120), nullable=False, unique=True) # 继承 ModelView,实现 CRUD 页面 class UserView(ModelView): column_searchable_list = ['username', 'email'] column_filters = ['username', 'email'] column_editable_list = ['username', 'email'] column_sortable_list = ['username', 'email'] # 创建 Admin 实例,注册模型视图 admin = Admin(app, index_view=MyAdminIndexView()) admin.add_view(UserView(User, db.session)) if __name__ == '__main__': app.run(debug=True) ``` 以上代码实现了一个简单的登录界面和一个数据管理页面,用户可以使用账号密码登录来访问数据管理页面。需要注意的是,这里使用了 Flask-Login 扩展来管理用户信息,使用 Flask-Admin 扩展来实现数据管理页面。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值