[Flask]-自定义Flask-用户登录
[Flask]-Customising Flask-user login
一直在为用户管理系统开发Flask-user,但是我找不到自定义登录页面和注册页面的方法。我使用 pip
安装了 flask-user
pip install flask-user
如有任何帮助,我们将不胜感激
在templates
文件夹中,新建文件夹flask_user
,可以将flask-user
使用的login.html
和register.html
页面复制到新文件夹中创建的文件夹。然后您可以根据您的要求修改它们。这些文件将覆盖 flask-user
使用的页面。
来自官方 flask-user 文档
您可以在 https://github.com/lingthio/Flask-User-starter-app
获得样板文件(应用示例)
其他学习资源
1。 Flask-mega 教程
这里有一些在线资源,可以真正帮助您自定义用户登录和其他主题:
https://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-v-user-logins
本教程使用 openid,但通过代码示例解释了所有内容,即
app/views.py
from flask import render_template, flash, redirect, session, url_for, request, g
from flask_login import login_user, logout_user, current_user, login_required
from app import app, db, lm, oid
from .forms import LoginForm
from .models import User
@app.route('/login', methods=['GET', 'POST'])
@oid.loginhandler
def login():
if g.user is not None and g.user.is_authenticated:
return redirect(url_for('index'))
form = LoginForm()
if form.validate_on_submit():
session['remember_me'] = form.remember_me.data
return oid.try_login(form.openid.data, ask_for=['nickname', 'email'])
return render_template('login.html',
title='Sign In',
form=form,
providers=app.config['OPENID_PROVIDERS'])
2。 Exploreflask.com
完整的免费分步指南。在 'users' 一章中还提供了一个完整的章节来解决您的问题。
默认的 flask-user BasicApp 具有基于电子邮件的授权。
- 我们可以改成基于用户的授权
更换模型
class User(db.Model, UserMixin):
__tablename__ = 'users'
id = db.Column(db.Integer, primary_key=True)
active = db.Column('is_active', db.Boolean(), nullable=False, server_default='1')
username = db.Column(db.String(100, collation='NOCASE'), nullable=False, unique=True)
password = db.Column(db.String(255), nullable=False, server_default='')
first_name = db.Column(db.String(100, collation='NOCASE'), nullable=False, server_default='')
last_name = db.Column(db.String(100, collation='NOCASE'), nullable=False, server_default='')
# Define the relationship to Role via UserRoles
roles = db.relationship('Role', secondary='user_roles')
在配置中更改以下行:
USER_ENABLE_EMAIL = False # Enable email authentication
USER_ENABLE_USERNAME = True # Disable username authentication
Insert the Default two users by Username. Replace Existing code by following code.
if not User.query.filter(User.username == 'member').first():
user = User(
username='member',
password=user_manager.hash_password('Password1'),
)
db.session.add(user)
db.session.commit()
# Create 'admin@example.com' user with 'Admin' and 'Agent' roles
if not User.query.filter(User.username == 'admin').first():
user = User(
username='admin',
password=user_manager.hash_password('Password1'),
)
user.roles.append(Role(name='Admin'))
user.roles.append(Role(name='Agent'))
db.session.add(user)
db.session.commit()
一直在为用户管理系统开发Flask-user,但是我找不到自定义登录页面和注册页面的方法。我使用 pip
安装了 flask-userpip install flask-user
如有任何帮助,我们将不胜感激
在templates
文件夹中,新建文件夹flask_user
,可以将flask-user
使用的login.html
和register.html
页面复制到新文件夹中创建的文件夹。然后您可以根据您的要求修改它们。这些文件将覆盖 flask-user
使用的页面。
来自官方 flask-user 文档
您可以在 https://github.com/lingthio/Flask-User-starter-app
获得样板文件(应用示例)其他学习资源
1。 Flask-mega 教程
这里有一些在线资源,可以真正帮助您自定义用户登录和其他主题:
https://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-v-user-logins
本教程使用 openid,但通过代码示例解释了所有内容,即
app/views.py
from flask import render_template, flash, redirect, session, url_for, request, g
from flask_login import login_user, logout_user, current_user, login_required
from app import app, db, lm, oid
from .forms import LoginForm
from .models import User
@app.route('/login', methods=['GET', 'POST'])
@oid.loginhandler
def login():
if g.user is not None and g.user.is_authenticated:
return redirect(url_for('index'))
form = LoginForm()
if form.validate_on_submit():
session['remember_me'] = form.remember_me.data
return oid.try_login(form.openid.data, ask_for=['nickname', 'email'])
return render_template('login.html',
title='Sign In',
form=form,
providers=app.config['OPENID_PROVIDERS'])
2。 Exploreflask.com
完整的免费分步指南。在 'users' 一章中还提供了一个完整的章节来解决您的问题。
默认的 flask-user BasicApp 具有基于电子邮件的授权。
- 我们可以改成基于用户的授权
更换模型
class User(db.Model, UserMixin): __tablename__ = 'users' id = db.Column(db.Integer, primary_key=True) active = db.Column('is_active', db.Boolean(), nullable=False, server_default='1') username = db.Column(db.String(100, collation='NOCASE'), nullable=False, unique=True) password = db.Column(db.String(255), nullable=False, server_default='') first_name = db.Column(db.String(100, collation='NOCASE'), nullable=False, server_default='') last_name = db.Column(db.String(100, collation='NOCASE'), nullable=False, server_default='') # Define the relationship to Role via UserRoles roles = db.relationship('Role', secondary='user_roles')
在配置中更改以下行:
USER_ENABLE_EMAIL = False # Enable email authentication USER_ENABLE_USERNAME = True # Disable username authentication
Insert the Default two users by Username. Replace Existing code by following code.
if not User.query.filter(User.username == 'member').first():
user = User(
username='member',
password=user_manager.hash_password('Password1'),
)
db.session.add(user)
db.session.commit()
# Create 'admin@example.com' user with 'Admin' and 'Agent' roles
if not User.query.filter(User.username == 'admin').first():
user = User(
username='admin',
password=user_manager.hash_password('Password1'),
)
user.roles.append(Role(name='Admin'))
user.roles.append(Role(name='Agent'))
db.session.add(user)
db.session.commit()