实战篇:用户管理模块开发

实战篇:用户管理模块开发

用户管理模块简介

用户管理模块是大多数Web应用的核心组件之一,它负责处理用户的注册、登录、信息展示、编辑和删除等操作。

项目结构

假设你已经根据之前讨论的结构组织了你的Flask项目。

第1步:定义用户模型

app/models/models.py中定义用户模型。

from app import db
from werkzeug.security import generate_password_hash, check_password_hashclass User(db.Model):__tablename__ = 'users'id = db.Column(db.Integer, primary_key=True)username = db.Column(db.String(64), unique=True, nullable=False)email = db.Column(db.String(120), unique=True, nullable=False)password_hash = db.Column(db.String(128))def set_password(self, password):self.password_hash = generate_password_hash(password)def check_password(self, password):return check_password_hash(self.password_hash, password)def __repr__(self):return '<User %r>' % self.username
第2步:创建数据库迁移

使用Flask-Migrate来创建新的数据库迁移。

flask db init  # 初始化迁移目录
flask db migrate -m "Add user table"
flask db upgrade  # 应用迁移
第3步:注册和登录路由

app/routes/routes.py中创建注册和登录的路由。

from flask import render_template, request, redirect, url_for, flash
from werkzeug.security import generate_password_hash
from app.models.models import User
from app import db@app.route('/register', methods=['GET', 'POST'])
def register():if request.method == 'POST':username = request.form['username']email = request.form['email']password = request.form['password']hashed_password = generate_password_hash(password, method='sha256')new_user = User(username=username, email=email)new_user.set_password(hashed_password)db.session.add(new_user)db.session.commit()flash('Your account has been created! You are now able to log in', 'success')return redirect(url_for('login'))return render_template('register.html')@app.route('/login', methods=['GET', 'POST'])
def login():# 登录逻辑pass@app.route('/logout')
def logout():# 登出逻辑pass
第4步:用户认证

使用Flask-Login来处理用户认证。

from flask_login import LoginManager, login_user, logout_user, login_requiredlogin_manager = LoginManager()
login_manager.init_app(app)@login_manager.user_loader
def load_user(user_id):return User.query.get(int(user_id))
第5步:用户资料页面

创建一个路由来展示用户的资料。

@app.route('/profile')
@login_required
def profile():user = current_user# 展示用户资料逻辑pass
第6步:用户编辑页面

允许用户编辑他们的个人信息。

@app.route('/edit-profile', methods=['GET', 'POST'])
@login_required
def edit_profile():user = current_userif request.method == 'POST':# 更新用户信息逻辑passreturn render_template('edit_profile.html', user=user)
第7步:测试用户管理模块

tests/test_models.pytests/test_routes.py中编写测试用例。

# 测试用户模型
def test_user_creation(app):user = User(username='testuser', email='test@example.com')db.session.add(user)db.session.commit()assert User.query.first() is not None# 测试注册路由
def test_register_route(client):response = client.post('/register', data={'username': 'testuser', 'email': 'test@example.com', 'password': 'testpassword'})assert response.status_code == 302  # or the appropriate status code
结语

在本实战篇中,我们开发了一个基本的用户管理模块,包括注册、登录、登出、用户资料展示和编辑功能。每个功能都有对应的路由和模板。


记得在开发过程中编写测试用例,并确保它们通过。这将帮助你确保代码的质量,并在将来重构或添加新功能时提供安全网。此外,考虑使用Flask-Security或Flask-User等扩展来简化用户认证和管理工作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/852403.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

牛客链表刷题(一)

目录 题目一&#xff1a;反转链表 代码&#xff1a; 题目二&#xff1a;链表内指定区间反转 代码&#xff1a; 题目一&#xff1a;反转链表 代码&#xff1a; import java.util.*;/** public class ListNode {* int val;* ListNode next null;* public ListNode(int …

2024 年最新 Python 使用 gewe 框架搭建微信机器人实现语音智能回复(详细教程)

Gewe 个微框架 GeWe&#xff08;个微框架&#xff09;是一个创新性的软件开发框架&#xff0c;专注于IPAD协议&#xff0c;为个人微信号以及企业信息安全提供了强大的功能和保障。GeWe的设计旨在简化开发过程&#xff0c;使开发者能够高效、灵活地构建和定制通信协议&#xff…

unity基础(五)地形详解

目录 一 创建地形 二 调整地形大小 三 创建相邻地形 四 创建山峰 五 创建树木 七 添加风 八 添加水 简介: Unity 中的基础地形是构建虚拟场景的重要元素之一。 它提供了一种直观且灵活的方式来创建各种地形地貌&#xff0c;如山脉、平原、山谷等。 通过 Unity 的地形…

Spring源码学习-Resource

Spring的Resource接口为资源访问提供了统一的接口&#xff0c;不同的实现类实现了从不同上下文获取资源。下面是该接口的方法: public interface Resource extends InputStreamSource {/*** Determine whether this resource actually exists in physical form.* <p>Thi…

力扣384. 打乱数组

Problem: 384. 打乱数组 文章目录 题目描述思路复杂度Code 题目描述 思路 打乱数组的主要算法&#xff1a; 从1 - n每次生成[i ~ n - i]的一个随机数字&#xff0c;再将原数组下标位置为i的元素和该随机数字位置的元素交换 复杂度 打乱数组的主要算法 时间复杂度: O ( n ) O(…

【Attack】拓扑缺陷图注入攻击

TDGIA: 图神经网络的有效注入攻击 图注入攻击下 GNN 的脆弱性TDGIA框架拓扑缺陷边选择平滑的对抗优化整体攻击流程 KDD’21 &#x1f604; 图注入攻击&#xff1a;攻击者无法修改输入图的现有link结构和节点属性&#xff0c;而是通过向其中注入对抗性节点来执行攻击。 图注入…

Linux操作系统学习路线

本文来自Qwen2大模型&#xff1a; Linux操作系统的全面学习是一个渐进的过程&#xff0c;涵盖从基础知识到高级特性的多个阶段。以下是一份详细的Linux操作系统学习路线图&#xff0c;包括各个阶段的学习目标、建议的学习资源和实践步骤。 1. Linux 基础知识与安装 学习目标&a…

vite构建的ts项目配置src别名@

一、安装types/node npm install types/node 二、vite.config.ts 文件中配置以下内容 resolve: {alias: {: path.resolve(__dirname, ./src),},}, 三、 tsconfig.json 文件中compilerOptions下配置以下内容 /* 配置 */"baseUrl": ".","paths":…

深度学习长文|使用 JAX 进行 AI 模型训练

引言 在人工智能模型的开发旅程中&#xff0c;选择正确的机器学习开发框架是一项至关重要的决策。历史上&#xff0c;众多库都曾竞相争夺“人工智能开发者首选框架”这一令人垂涎的称号。&#xff08;你是否还记得 Caffe 和 Theano&#xff1f;&#xff09;在过去的几年里&…

Python | Leetcode Python题解之第149题直线上最多的点数

题目&#xff1a; 题解&#xff1a; class Solution:def maxPoints(self, points: List[List[int]]) -> int:n len(points)if n < 2:return nres 2for i in range(n):x1, y1 points[i][0], points[i][1]has {}for j in range(i 1, n):x2, y2 points[j][0], points…

怎么沉淀自己的价值——笔记

怎么寻找自己的特长 领导爱交给你啥任务 同事爱找你唠啥 好友对你的印象是啥 你干啥时最享受 经验 经历过的自己总结的有规律的知识。 回顾总结->Star框架&#xff0c;情景、任务、行动、结果 归类反思->合并归类、反思总结 课程 课程 知识 形式&#xff08;图文、…

随心笔记,第六更

目录 一、 三步构建 XML转成java bean 1.XML转XSD 2.XSD转JavaBean 3.jaxb 工具类 4.测试 &#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是「Leen」。刚工作几年&#xff0c;想和大家一同进步&am…

ESP RainMaker®为企业提供AIoT云解决方案,启明云端乐鑫代理商

在AIoT的浪潮中&#xff0c;企业面临着前所未有的机遇与挑战。如何快速响应市场变化&#xff0c;开发出具有竞争力的智能产品&#xff1f;如何确保数据安全&#xff0c;同时实现高效的设备管理&#xff1f;这些问题&#xff0c;ESP RainMaker给出了答案。 ESP RainMaker是一个…

STM32程序启动过程

&#xff08;1&#xff09;首先对栈和堆的大小进行定义&#xff0c;并在代码区的起始处建立中断向量表&#xff0c;其第一个表项是栈顶地址&#xff08;32位&#xff09;&#xff0c;第二个表项是复位中断服务入口地址&#xff1b; &#xff08;2&#xff09;然后执行复位中断&…

了解TF-IDF:一种文本分析的强大工具

了解TF-IDF&#xff1a;一种文本分析的强大工具 在现代信息时代&#xff0c;海量的文本数据充斥着我们的生活。如何有效地从这些文本数据中提取有价值的信息成为了一个关键问题。TF-IDF&#xff08;Term Frequency-Inverse Document Frequency&#xff09;作为一种经典的文本分…

如何将NextJs中的File docx保存到Prisma ORM

背景/引言 在现代 Web 开发中&#xff0c;Next.js 是一个备受欢迎的 React 框架&#xff0c;它具有许多优点&#xff0c;如&#xff1a; 服务器端渲染 (SSR)&#xff1a;Next.js 支持服务器端渲染&#xff0c;可以提高页面加载速度&#xff0c;改善 SEO&#xff0c;并提供更好…

【Tools】理解图像与像素矩阵

是你多么温馨的目光 教我坚毅望着前路 叮嘱我跌倒不应放弃 没法解释怎可报尽亲恩 爱意宽大是无限 请准我说声真的爱你 &#x1f3b5; Beyond《真的爱你》 引言 在数字图像处理中&#xff0c;我们经常听到“像素矩阵”这个术语。无论你是在处理一张简单的…

即插即用!CVD:第一个生成具有相机控制的多视图一致视频方案!(斯坦福港中文)

论文链接&#xff1a;https://arxiv.org/abs/2405.17414 项目链接&#xff1a;https://collaborativevideodiffusion.github.io/ 最近对视频生成的研究取得了巨大进展&#xff0c;使得可以从文本提示或图像生成高质量的视频。在视频生成过程中添加控制是未来的重要目标&#x…

Kafka 操作之分层存储(Tiered Storage)

目录 一. 前言 二. 分层存储&#xff08;Tiered Storage&#xff09; 2.1. 分层存储概述&#xff08;Tiered Storage Overview&#xff09; 2.2. 配置&#xff08;Configuration&#xff09; 2.2.1. Broker 配置&#xff08;Broker Configurations&#xff09; 2.2.2. To…

笔记99:OSQP 求解器示例代码

注1&#xff1a;以下代码是 OSQP 的官方文档提供的示例&#xff0c;我加上了详细的注释&#xff1b; 注2&#xff1a;OSQP 库仅支持C语言&#xff0c;不支持C&#xff0c;所以下面的示例代码使用的是C语言&#xff1b;但是 OSQP 求解库提供了针对C的接口 OSQP-EIGEN&#xff1…