一个基于 Flask + SocketIO 的加密聊天室应用,支持匿名聊天和管理员后台监控。
English
项目简介
Secret Chatting 是一个轻量级的私密聊天室系统。用户通过房间号和密码加入聊天室,支持自定义昵称,所有消息实时传输并持久化存储。管理员可通过后台监控所有房间的聊天记录、创建和删除房间,并可直接在房间内发送管理消息。系统首次使用时提供可视化初始化向导,自动完成数据库创建和管理员设置。前端采用仿微信风格设计,体验流畅自然。
功能特性
技术栈
项目结构
secret-chatting/
├── app.py # 应用入口,路由与 SocketIO 事件
├── config.py # 配置管理
├── models.py # 数据模型( Room, Message, Admin )
├── requirements.txt # Python 依赖
├── .env # 环境变量
├── static/
│ ├── css/
│ │ ├── style.css # 客户端样式
│ │ └── admin.css # 管理端样式
│ └── js/
│ ├── app.js # 客户端逻辑
│ └── admin.js # 管理端逻辑
└── templates/
├── index.html # 客户端页面
├── admin.html # 管理端页面
└── setup.html # 系统初始化页面
快速开始
1. 安装依赖
pip install -r requirements.txt
2. 启动服务
python app.py
3. 系统初始化
首次启动时,访问任意页面会自动跳转到初始化页面(/setup),需完成以下步骤:
[ol]
[/ol]
初始化完成后自动跳转到管理后台登录页。
系统已初始化后,访问 /setup 会自动跳转到管理后台。
4. 访问页面
[td]页面[/td]
[td]地址[/td]
[td]说明[/td]
聊天室
http://localhost:5000
用户聊天入口
系统初始化
http://localhost:5000/setup
首次使用时自动跳转
管理后台
http://localhost:5000/admin
管理员登录后管理房间
配置说明
通过 .env 文件或环境变量配置:
[td]变量[/td]
[td]说明[/td]
[td]默认值[/td]
SECRET_KEY
Flask 密钥
dev-secret-key-change-this-in-production
DATABASE_URL
数据库连接字符串
sqlite:///secret_chatting.db
数据模型
License
MIT

