kindergarten_java/reading-platform-java
Claude Opus 4.6 56508eb066 feat: 三端全链路测试完成 - 学校端、教师端、课程包业务
## 后端修复
- 修复教师端课程查询 - 包含系统课程和租户课程
- 修复系统课程创建 - isSystem 标志正确保存到数据库
- 新增套餐授权接口 POST /api/v1/admin/packages/{id}/grant

## 新增 Controller
- SchoolStatsController - 学校端统计数据
- SchoolCourseController - 学校端课程管理
- TeacherStatsController - 教师端统计数据

## 前端修复
- 修复 API 客户端导入 - getApi → getReadingPlatformAPI
- 修复三端 API 调用方法名
- 更新 Orval 生成配置和 API 类型
- 修复学校端视图 - result.items → result.list

## 测试结果
-  超管端:课程创建/发布、套餐完整流程、授权
-  学校端:登录、统计、课程、套餐查看
-  教师端:登录、Dashboard、班级、课程查看

## 文档更新
- 新增测试记录:/docs/test-logs/
- 更新 CHANGELOG.md
- 更新今日开发日志

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-13 13:48:28 +08:00
..
src/main feat: 三端全链路测试完成 - 学校端、教师端、课程包业务 2026-03-13 13:48:28 +08:00
db_migrate.py feat: Java后端迁移完成 - 资源管理API修复与文档更新 2026-03-12 19:49:48 +08:00
db-migrate.sh feat: Java后端迁移完成 - 资源管理API修复与文档更新 2026-03-12 19:49:48 +08:00
init-users.sql fix: 修复登录问题 - 所有角色登录功能正常 2026-03-12 20:02:48 +08:00
pom.xml feat: Java后端迁移完成 - 资源管理API修复与文档更新 2026-03-12 19:49:48 +08:00
README.md 提交说明 2026-02-28 16:41:39 +08:00

Reading Platform Java Backend

Spring Boot + MyBatis-Plus backend for the Reading Platform.

Tech Stack

  • Java: 17
  • Spring Boot: 3.2.3
  • MyBatis-Plus: 3.5.5
  • MySQL: 8.0+
  • Spring Security + JWT: Authentication
  • Knife4j: API Documentation (Swagger)
  • Lombok: Boilerplate reduction

Project Structure

reading-platform-java/
├── pom.xml                          # Maven dependencies
├── src/main/java/com/reading/platform/
│   ├── ReadingPlatformApplication.java
│   ├── common/                      # Common components
│   │   ├── config/                  # Configuration classes
│   │   ├── exception/               # Exception handling
│   │   ├── response/                # Unified response
│   │   ├── security/                # JWT security
│   │   ├── annotation/              # Custom annotations
│   │   ├── enums/                   # Enum classes
│   │   ├── aspect/                  # AOP aspects
│   │   └── util/                    # Utilities
│   ├── entity/                      # Entity classes (27)
│   ├── mapper/                      # MyBatis-Plus mappers (27)
│   ├── service/                     # Service interfaces
│   ├── service/impl/                # Service implementations
│   ├── controller/                  # REST controllers
│   │   ├── admin/                   # Super admin endpoints
│   │   ├── school/                  # School admin endpoints
│   │   ├── teacher/                 # Teacher endpoints
│   │   └── parent/                  # Parent endpoints
│   └── dto/                         # Data Transfer Objects
│       ├── request/
│       └── response/
└── src/main/resources/
    ├── application.yml              # Main configuration
    ├── application-dev.yml          # Dev environment config
    ├── mapper/                      # MyBatis XML files
    └── db/migration/                # SQL scripts

Quick Start

1. Prerequisites

  • JDK 17+
  • Maven 3.6+
  • MySQL 8.0+

2. Database Setup

# Create database and import schema
mysql -u root -p < src/main/resources/db/migration/V1__init_schema.sql

3. Configuration

Edit src/main/resources/application-dev.yml:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/reading_platform
    username: your_username
    password: your_password

4. Build and Run

# Build
mvn clean package -DskipTests

# Run
java -jar target/reading-platform-1.0.0.jar

# Or run with Maven
mvn spring-boot:run

5. API Documentation

After starting the application, access the API documentation at:

API Endpoints

Authentication

  • POST /api/auth/login - User login
  • GET /api/auth/me - Get current user info
  • POST /api/auth/change-password - Change password

Admin Endpoints

  • /api/admin/tenants - Tenant management
  • /api/admin/courses - System course management

School Endpoints

  • /api/school/teachers - Teacher management
  • /api/school/students - Student management
  • /api/school/classes - Class management
  • /api/school/parents - Parent management
  • /api/school/tasks - Task management
  • /api/school/growth-records - Growth record management

Teacher Endpoints

  • /api/teacher/courses - View courses
  • /api/teacher/lessons - Lesson management
  • /api/teacher/tasks - Task management
  • /api/teacher/growth-records - Growth record management
  • /api/teacher/notifications - Notifications

Parent Endpoints

  • /api/parent/children - Child information
  • /api/parent/tasks - View and complete tasks
  • /api/parent/growth-records - Growth record management
  • /api/parent/notifications - Notifications

Test Accounts

Role Username Password
Admin admin admin123

School, teacher, and parent accounts need to be created through the admin interface.

Database Tables (27)

Module Tables
Tenant tenants, tenant_courses
Users admin_users, teachers, students, parents, parent_students
Class classes, class_teachers, student_class_history
Course courses, course_versions, course_resources, course_scripts, course_script_pages, course_activities
Lesson lessons, lesson_feedbacks, student_records
Task tasks, task_targets, task_completions, task_templates
Growth growth_records
Resource resource_libraries, resource_items
Schedule schedule_plans, schedule_templates
System system_settings, notifications, operation_logs, tags

Development

Adding a New Entity

  1. Create entity class in entity/
  2. Create mapper interface in mapper/
  3. Create service interface in service/
  4. Create service implementation in service/impl/
  5. Create controller in appropriate controller/ subdirectory

Code Style

  • Use Lombok annotations to reduce boilerplate
  • Follow Spring Boot conventions
  • Use @RequireRole annotation for role-based access control

License

MIT License