AI-Quiz是一套基于python开发的在线评测系统,整体采用fast-api框架,后端通过api提供服务,后端的api采用python开发,便于接入AI接口,管理端采用python进行开发,前端,也就是用户端,采用uniapp开发,支持发布小程序和h5,没有PC端版本。ui采用图鸟UI 和taiwind。美观大方。 Dash-FastAPI-Admin是一套全部开源的快速开发平台,毫无保留给个人及企业免费使用。
- 管理前端采用Dash、feffery-antd-components、feffery-utils-components。
- 后端采用FastAPI、sqlalchemy、MySQL(PostgreSQL)、Redis、OAuth2 & Jwt。
- 权限认证使用OAuth2 & Jwt,支持多终端认证系统。
- 支持加载动态权限菜单,多方式轻松权限控制。
- 前端采用uniapp
- 支持多种AI接口,目前支持openai等,更多的ai接口接入中
- 支持多种测试量表,量表也在不断添加中。
- 特别鸣谢:insistence 。
- v1.0.0 完成基本框架
- v1.0.1 完成后台量表数据管理
- 用户管理:用户是系统操作者,该功能主要完成系统用户配置。
- 角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。
- 菜单管理:配置系统菜单,操作权限,按钮权限标识等。
- 部门管理:配置系统组织机构(公司、部门、小组)。
- 岗位管理:配置系统用户所属担任职务。
- 字典管理:对系统中经常使用的一些较为固定的数据进行维护。
- 参数管理:对系统动态配置常用参数。
- 通知公告:系统通知公告信息发布维护。
- 操作日志:系统正常操作日志记录和查询;系统异常信息日志记录和查询。
- 登录日志:系统登录日志记录查询包含登录异常。
- 在线用户:当前系统中活跃用户状态监控。
- 定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。
- 服务监控:监视当前系统CPU、内存、磁盘、堆栈等相关信息。
- 缓存监控:对系统的缓存信息查询,命令统计等。
- 系统接口:根据业务代码自动生成相关的api接口文档。
- 会员管理:使用系统的会员进行管理
- 量表管理:管理量表,增加修改删除量表及其关联的表单项
- 账号:admin
- 密码:admin123
- 演示地址:AI-Quiz管理中心
# 克隆项目
git clone https://github.com/reddts/AI-Quiz.git
# 进入项目根目录
cd AI-Quiz
# 如果使用的是MySQL数据库,请执行以下命令安装项目依赖环境
pip3 install -r requirements.txt
# 如果使用的是PostgreSQL数据库,请执行以下命令安装项目依赖环境
pip3 install -r requirements-pg.txt
# 进入前端目录
cd fastapi-frontend
# 配置应用信息
在.env.dev文件中配置应用开发模式的相关信息
# 运行前端
python3 app.py --env=dev
# 进入后端目录
cd fastapi-backend
# 配置环境
1.在.env.dev文件中配置开发模式的数据库环境
2.在.env.dev文件中配置开发模式的redis环境
# 运行sql文件
1.新建数据库ai-quiz(默认,可修改)
2.如果使用的是MySQL数据库,使用命令或数据库连接工具运行sql文件夹下的ai-quiz.sql;如果使用的是PostgreSQL数据库,使用命令或数据库连接工具运行sql文件夹下的ai-quiz-pg.sql
# 运行后端
python3 app.py --env=dev
本应用发布建议使用nginx部署,nginx代理配置参考如下:
server {
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8088/;
}
location /prod-api {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:9099/;
rewrite ^/prod-api/(.*)$ /$1 break;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
# 进入前端目录
cd fastapi-frontend
# 配置应用信息
在.env.prod文件中配置应用发布的相关信息,注意:APP_BASE_URL需要配置为nginx代理的地址,例如上面的nginx代理监听的是8000端口,则APP_BASE_URL需要配置为http://127.0.0.1:8000
# 运行前端
python3 wsgi.py --env=prod
# 进入后端目录
cd fastapi-backend
# 配置环境
1.在.env.prod文件中配置生产模式的数据库环境
2.在.env.prod文件中配置生产模式的redis环境
# 运行sql文件
1.新建数据库ai-quiz(默认,可修改)
2.如果使用的是MySQL数据库,使用命令或数据库连接工具运行sql文件夹下的ai-quiz.sql;如果使用的是PostgreSQL数据库,使用命令或数据库连接工具运行sql文件夹下的ai-quiz-pg.sql
# 运行后端
python3 app.py --env=prod
# 默认账号密码
账号:admin
密码:admin123
# 浏览器访问
地址:http://127.0.0.1:8088
如果有对本项目及FastAPI和AI感兴趣的朋友,欢迎入群交流。如果你觉得这个项目帮助到了你,你可以请作者喝杯咖啡表示鼓励☕。扫描下面微信二维码添加微信备注AI-Quiz即可进群。