见 绮课简介
此文档可能并不足够详尽,如遇到问题,请联系作者
- 你心爱的命令行终端和代码编辑器
- 安装 Node.JS 运行环境: Node.js 12.22.0 或更高版本;
- 安装 yarn
- 安装 MySQL 8.0
git clone https://github.com/huayemao/cheerTimetable-web.git
或 git clone git@github.com:huayemao/cheerTimetable-web.git
- 数据库:准备一个 mysql 数据库实例,
或者使用 PlanetScale 提供的服务,这也是目前绮课在生产环境所使用的。 - 获取教务系统 jwctest 环境以 kbuser 课表数据查询用户登录后获得的 cookie,详见 绮课如何从教务系统抓取数据 | Dors.——花野猫的数字花园
- 在项目根目录创建环境变量文件 .env,使用 MySQL 数据库连接字符串和获得的 COOKIE 填写以下环境变量
DATABASE_URL='mysql://root:huayemao123@localhost:3306/cheerTimetable'
COOKIE='JSESSION_ID=XXX'
使用 npm install
或 yarn
命令安装 npm 依赖
- 运行
yarn db:generate
- 运行
yarn db:seed
,自动从教务系统导入数据
运行 yarn dev
将以开发模式启动 Next.js 项目,更多请见 Next.js 文档
├── _data // 以异步 IIFE 导出从教务系统获取数据所需的 JSON
├── components // React 组件
├── constants // 常量
├── contexts // 存放 React Contexts
├── lib // 抽出的工具函数
├── pages // Next.js 路由页面
├── prisma // 数据库相关,包括模式定义和数据库导入脚本