基于Flask 3.1和Python 3.13的简易CMS

以下是一个基于Flask 3.1和Python 3.13的简易CMS管理系统实现方案,包含核心功能和可运行代码示例。

环境准备

安装Flask和其他依赖库:

pip install flask==3.1.0 flask-sqlalchemy flask-login

配置数据库

config.py中设置SQLite数据库URI:

import osbasedir = os.path.abspath(os.path.dirname(__file__))class Config:SQLALCHEMY_DATABASE_URI = 'sqlite:///' + os.path.join(basedir, 'app.db')SQLALCHEMY_TRACK_MODIFICATIONS = False

项目结构

/cms_app/static/templatesbase.htmllogin.htmldashboard.htmlposts.htmlapp.pyconfig.py

核心代码实现

配置文件和初始化(config.py)
import osclass Config:SECRET_KEY = os.environ.get('SECRET_KEY') or 'your-secret-key-here'SQLALCHEMY_DATABASE_URI = 'sqlite:///site.db'SQLALCHEMY_TRACK_MODIFICATIONS = False
主应用文件(app.py)
from flask import Flask, render_template, redirect, url_for, request
from flask_sqlalchemy import SQLAlchemy
from flask_login import LoginManager, UserMixin, login_user, logout_user, login_required
from config import Configapp = Flask(__name__)
app.config.from_object(Config)
db = SQLAlchemy(app)
login_manager = LoginManager(app)
login_manager.login_view = 'login'# 用户模型
class User(UserMixin, db.Model):id = db.Column(db.Integer, primary_key=True)username = db.Column(db.String(80), unique=True, nullable=False)password = db.Column(db.String(120), nullable=False)# 内容模型
class Post(db.Model):id = db.Column(db.Integer, primary_key=True)title = db.Column(db.String(100), nullable=False)content = db.Column(db.Text, nullable=False)@login_manager.user_loader
def load_user(user_id):return User.query.get(int(user_id))@app.route('/')
@login_required
def dashboard():posts = Post.query.all()return render_template('dashboard.html', posts=posts)@app.route('/login', methods=['GET', 'POST'])
def login():if request.method == 'POST':username = request.form['username']password = request.form['password']user = User.query.filter_by(username=username).first()if user and user.password == password:login_user(user)return redirect(url_for('dashboard'))return render_template('login.html')@app.route('/logout')
@login_required
def logout():logout_user()return redirect(url_for('login'))@app.route('/post/new', methods=['GET', 'POST'])
@login_required
def new_post():if request.method == 'POST':post = Post(title=request.form['title'], content=request.form['content'])db.session.add(post)db.session.commit()return redirect(url_for('dashboard'))return render_template('new_post.html')if __name__ == '__main__':with app.app_context():db.create_all()app.run(debug=True)

模板文件示例

base.html(模板基础文件)
<!DOCTYPE html>
<html>
<head><title>CMS System</title>
</head>
<body>{% block content %}{% endblock %}
</body>
</html>
login.html(登录页面)
{% extends "base.html" %}
{% block content %}
<h2>Login</h2>
<form method="POST"><input type="text" name="username" placeholder="Username" required><input type="password" name="password" placeholder="Password" required><button type="submit">Login</button>
</form>
{% endblock %}

运行系统

创建初始数据库和用户:

from app import app, db, User
with app.app_context():db.create_all()admin = User(username='admin', password='admin123')db.session.add(admin)db.session.commit()

启动开发服务器:

python app.py

系统将运行在http://127.0.0.1:5000,使用admin/admin123登录后可管理内容。

功能扩展建议

  1. 添加用户注册功能
  2. 实现文章分类和标签
  3. 增加富文本编辑器
  4. 添加文件上传功能
  5. 实现权限管理系统

添加用户注册功能

项目结构

创建以下目录结构:

app/__init__.pymodels.pyroutes.pytemplates/register.htmllogin.htmldashboard.html
config.py
run.py

初始化Flask应用

app/__init__.py中创建应用实例:

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from config import Configapp = Flask(__name__)
app.config.from_object(Config)
db = SQLAlchemy(app)from app import routes, models

定义用户模型

app/models.py中创建User模型:

from app import dbclass User(db.Model):id = db.Column(db.Integer, primary_key=True)username = db.Column(db.String(64), index=True, unique=True)email = db.Column(db.String(120), index=True, unique=True)password_hash = db.Column(db.String(128))def __repr__(self):return f'<User {self.username}>'

创建路由和视图

app/routes.py中实现CRUD操作:

from flask import render_template, redirect, url_for, request, flash
from app import app, db
from app.models import User@app.route('/register', methods=['GET', 'POST'])
def register():if request.method == 'POST':username = request.form['username']email = request.form['email']password = request.form['password']existing_user = User.query.filter_by(username=username).first()if existing_user:flash('Username already exists')return redirect(url_for('register'))new_user = User(username=username, email=email, password_hash=password)db.session.add(new_user)db.session.commit()flash('Registration successful')return redirect(url_for('login'))return render_template('register.html')@app.route('/users')
def users():users = User.query.all()return render_template('dashboard.html', users=users)@app.route('/delete/<int:id>')
def delete(id):user = User.query.get_or_404(id)db.session.delete(user)db.session.commit()return redirect(url_for('users'))

创建模板文件

templates/register.html中创建注册表单:

<!DOCTYPE html>
<html>
<head><title>Register</title>
</head>
<body><h1>Register</h1><form method="POST" action="{{ url_for('register') }}"><input type="text" name="username" placeholder="Username" required><input type="email" name="email" placeholder="Email" required><input type="password" name="password" placeholder="Password" required><button type="submit">Register</button></form>
</body>
</html>

templates/dashboard.html中显示用户列表:

<!DOCTYPE html>
<html>
<head><title>Users</title>
</head>
<body><h1>User List</h1><ul>{% for user in users %}<li>{{ user.username }} - {{ user.email }}<a href="{{ url_for('delete', id=user.id) }}">Delete</a></li>{% endfor %}</ul>
</body>
</html>

运行应用

run.py中创建启动脚本:

from app import app, db
from app.models import User@app.before_first_request
def create_tables():db.create_all()if __name__ == '__main__':app.run(debug=True)

运行应用:

python run.py

数据库迁移

建议使用Flask-Migrate处理数据库变更:

pip install flask-migrate

修改app/__init__.py

from flask_migrate import Migratemigrate = Migrate(app, db)

初始化迁移仓库:

flask db init
flask db migrate -m "initial migration"
flask db upgrade

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

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

相关文章

用 Node.js 构建模块化的 CLI 脚手架工具,从 GitHub 下载远程模板

本文将手把手带你构建一个支持远程模板下载、自定义项目名称&#xff0c;并完成模块化拆分的 CLI 脚手架工具&#xff0c;适用于初创项目、团队内部工具或者开源项目快速初始化。&#x1f9e9; 为什么要自己造一个 CLI 脚手架&#xff1f; 在日常开发中&#xff0c;我们常用脚手…

08.如何正确关闭文件

如何正确关闭文件(File Handling Best Practices) 文件操作是日常开发中非常常见的任务,正确关闭文件对于避免资源泄漏尤为关键。错误的文件关闭方式可能导致文件未保存、锁定或其他异常。 1. 常见的错误方式:手动 close() 许多初学者会手动调用 close() 关闭文件,这在异…

算法入门--动态规划(C++)

深入浅出掌握动态规划核心思想&#xff0c;图文并茂实战代码 什么是动态规划&#xff1f; 动态规划&#xff08;Dynamic Programming, DP&#xff09; 是一种高效解决多阶段决策问题的方法。它通过将复杂问题分解为重叠子问题&#xff0c;并存储子问题的解&#xff08;避免重…

[2025CVPR]GNN-ViTCap:用于病理图像分类与描述模型

论文结构解析​ 本文采用经典学术论文结构: ​引言​:阐述病理图像分析的挑战与现有方法局限性​相关工作​:系统梳理MIL、视觉语言预训练和生物医学语言模型三大领域​方法​:详细阐述GNN-ViTCap四阶段架构​实验​:在BreakHis和PatchGastric数据集验证性能​讨论​:通…

Java SE--图书管理系统模拟实现

一.设计思路首先这个系统可以由俩种用户使用&#xff0c;分别为管理者用户和普通者用户&#xff0c;根据不同的用户有不同的界面&#xff0c;每个界面有不同的功能。二.代码实现创建三个包和一个类book包&#xff1a;包括Book类和Booklist类Book类&#xff1a;package book; pu…

[RPA] 批量数据抓取指定商品名称信息

影刀RPA案例&#xff1a;批量数据抓取指定商品名称信息流程图&#xff1a;操作步骤&#xff1a;涉及的影刀RPA大致指令&#xff1a; 1. 打开影刀商城页面 2. 使用【填写输入框(web)】指令输入用户名和密码&#xff0c;并点击"登录"按钮 3. 切换到"订单管理"…

我的世界Java版1.21.4的Fabric模组开发教程(十四)方块实体

这是适用于Minecraft Java版1.21.4的Fabric模组开发系列教程专栏第十四章——方块实体。想要阅读其他内容&#xff0c;请查看或订阅上面的专栏。 方块实体(Block Entity) 指的是一种用于存储方块额外数据的方法。但这种数据和为了控制方块状态而在自定义方块类中创建的属性不太…

【UE教程/进阶】UE中的指针与引用

目录直接属性引用共享指针 TSharedPtr实现原理共享引用 TSharedRef弱引用指针 TWeakPtrObject弱指针 FWeakPtr实现原理Object软指针 FSoftObjectPtr原理直接属性引用 在c通过UPROPERTY()宏将属性公开&#xff0c;蓝图中属性类型中的Object Reference。 对一个类型及其子类型的…

早期 CNN 的经典模型—卷积神经网络(LeNet)

目录 LeNet 的设计背景与目标 LeNet 的网络结构&#xff08;经典 LeNet-5&#xff09; 局部感受野详解 一、局部感受野和全连接网络的区别 1. 传统全连接网络的问题 2. 局部感受野的解决方案 二、局部感受野的优势 1. 参数大幅减少 2. 提取局部特征 3. 平移不变性 参数…

RabbitMQ 高级特性之延迟队列

1. 简介 在某些场景下&#xff0c;当生产者发送消息后&#xff0c;可能不需要让消费者立即接收到&#xff0c;而是让消息延迟一段时间后再发送给消费者。 2. 实现方式 2.1 TTL 死信队列 给消息设置过期时间后&#xff0c;若消息在这段时间内没有被消费&#xff0c;就会将消…

uniapp app安卓下载文件 图片 doc xls 数据流文件 app安卓本地路径下载保存

//下载图片 downloadToLocal() {plus.android.requestPermissions([android.permission.WRITE_EXTERNAL_STORAGE],(success) > {uni.saveImageToPhotosAlbum({filePath: /static/x.png,//本地地址success: () > {this.$refs.uToast.show({message: "模版下载成功&am…

Context Engineering:从Prompt Engineering到上下文工程的演进

最近在做Deepresearch以及刷到一个不错的文章&#xff1a;context-engineering-guide &#xff0c;这篇文章揭示了提示工程以及上下文过程在智能体应用开源流程中&#xff0c;包括Deepresearch&#xff0c;MCP在内的一些概念&#xff0c;起到了非常重要的作用&#xff01; Cont…

jenkins部署vue前端项目

文章目录前言一、安装nginx二、jenkins构建项目总结前言 前面已经使用jenkins部署了后端springboot项目&#xff0c;现在开始学习jenkins部署前端Vue项目。 一、安装nginx 访问nginx官网&#xff0c;https://nginx.org/en/download.html下载tar包 上传到服务器目录中 然后到…

设计总监年中复盘:用Adobe XD内容识别布局,告别“手动调距”

时至年中&#xff0c;这不仅是检视上半年项目成果的节点&#xff0c;更是优化团队工作流、为下半年挑战储备动能的关键时期。在海外设计界工作的十余年间&#xff0c;我发现&#xff0c;一个高效的设计团队与一个疲于奔命的团队之间&#xff0c;最大的差别往往就在于是否建立了…

Unity 在Rider中通过Lingma插件使用MCP

环境&#xff1a; Unity 2022.3.12f1 JetBrains Rider 2025.1.4 Lingma 2.5.14 Python 3.13.4 下载包 首先在unity package manager 加入unity-mcp包 https://github.com/justinpbarnett/unity-mcp.git 然后下载uv包&#xff08;要先先下载python&#xff09;,网上很多…

pycharm+SSH 深度学习项目 远程后台运行命令

pycharmSSH 深度学习项目 远程后台运行命令碎碎念&#xff0c;都是实验室里那说关机就关机&#xff0c;说重启就重启的台式机逼得。。学吧记录 运行&#xff1a;nohup /root/miniconda3/bin/python -u "run.py" > /root/log/nohup.log 2>&1 &实时查看日…

【Linux | 网络】应用层(HTTP)

目录一、认识URL二、urlencode和urldecode三、HTTP协议格式&#xff08;使用Fiddler抓包&#xff09;3.1 安装并使用Fiddler抓包3.2 HTTP协议格式3.2.1 HTTP请求3.2.1.1 资源URL路径3.2.1.2 请求方法&#xff08;Method&#xff09;3.2.1.3 Location头字段&#xff08;重定向相…

编程实践:单例模式(懒汉模式+饿汉模式)

说明:本专栏文章有两种解锁方案 1:付费订阅,畅享所有文章 2:免费获取,点击下方链接,关注,自动获取免费链接 https://free-img.400040.xyz/4/2025/04/29/6810a50b7ac8b.jpg 主题:C++ 单例模式 什么是单例模式

破局电机制造四大痛点:MES与AI视觉的协同智造实践

万界星空科技电机行业MES系统解决方案是针对电机制造过程中多工序协同难、质量追溯复杂、设备管理要求高等痛点设计的数字化管理系统。一、电机行业的核心痛点1. 多工序协同困难 电机制造涉及绕线、装配、测试等多道工序&#xff0c;工艺衔接复杂&#xff0c;传统人工调度效率…

HTML 初体验

HTML&#xff08;超文本标记语言&#xff09;全称&#xff1a;HyperText Markup Language。超文本是什么&#xff1f;答&#xff1a;超文本就是网页中的链接。标记是什么&#xff1f;答&#xff1a;标记也叫标签&#xff0c;是带尖括号的文本。需求1&#xff1a;将“我爱中国”…