8422645625
Task 6.2 - 报告导出功能: - ReportExportService: 报告导出服务 - ExportToMarkdown: Markdown 格式导出 - ExportToHtml: HTML 格式导出(可打印为 PDF) - ExportToPdf: PDF 导出(HTML 包装) Task 10.1-10.3 - 文档和打包: - README.md: 项目主文档 - docs/USAGE.md: 使用指南(CLI 命令、API、Web 界面) - docs/DEVELOPMENT.md: 开发指南(项目结构、构建、测试、部署) - docs/API.md: API 参考文档(端点、认证、错误码) - Dockerfile: Web API Docker 镜像 - docker-compose.yml: Docker Compose 配置 - .dockerignore: Docker 忽略文件 - NuGet 打包配置 (CodePlay.Core.csproj) 测试:42 个 (41 通过,1 跳过) ✅ 新增文件: - CodePlay.Core/Services/ReportExportService.cs - README.md - docs/USAGE.md - docs/DEVELOPMENT.md - docs/API.md - Dockerfile - docker-compose.yml - .dockerignore Co-authored-by: monkeycode-ai <monkeycode-ai@chaitin.com>
129 lines
2.2 KiB
Markdown
129 lines
2.2 KiB
Markdown
# CodePlay 开发指南
|
|
|
|
## 项目结构
|
|
|
|
```
|
|
CodePlay/
|
|
├── CodePlay.Core/ # 核心转换引擎
|
|
├── CodePlay.Persistence/ # 数据持久化层
|
|
├── CodePlay.WebAPI/ # ASP.NET Core Web API
|
|
├── CodePlay.CLI/ # 命令行工具
|
|
├── CodePlay.Web/ # Vue3 前端
|
|
├── CodePlay.WebUI/ # Blazor 管理端
|
|
└── CodePlay.Tests/ # 单元测试
|
|
```
|
|
|
|
## 开发环境配置
|
|
|
|
### 1. 安装 .NET 8.0 SDK
|
|
https://dotnet.microsoft.com/download
|
|
|
|
### 2. 安装 Node.js 18+
|
|
https://nodejs.org/
|
|
|
|
### 3. 克隆并还原依赖
|
|
```bash
|
|
git clone <repository-url>
|
|
cd CodePlay
|
|
dotnet restore
|
|
```
|
|
|
|
### 4. 安装前端依赖
|
|
```bash
|
|
cd CodePlay.Web
|
|
npm install
|
|
```
|
|
|
|
## 构建和测试
|
|
|
|
### 编译所有项目
|
|
```bash
|
|
dotnet build
|
|
```
|
|
|
|
### 运行单元测试
|
|
```bash
|
|
dotnet test --logger "console;verbosity=normal"
|
|
```
|
|
|
|
### 查看测试覆盖率
|
|
```bash
|
|
dotnet test /p:CollectCoverage=true
|
|
```
|
|
|
|
### 代码格式化
|
|
```bash
|
|
dotnet format
|
|
```
|
|
|
|
## 添加新功能
|
|
|
|
### 1. 添加新的转换器
|
|
1. 在 `CodePlay.Core/Converters/` 创建新类
|
|
2. 实现 `IConverter` 接口
|
|
3. 在 `ConversionService` 中注册
|
|
|
|
### 2. 添加新的 API 端点
|
|
1. 在 `CodePlay.WebAPI/Controllers/` 创建控制器
|
|
2. 添加 `[Authorize]` 特性 (如需认证)
|
|
3. 实现 CRUD 方法
|
|
|
|
### 3. 添加前端组件
|
|
1. 在 `CodePlay.Web/src/components/` 创建组件
|
|
2. 在 `views/` 创建页面
|
|
3. 更新路由配置
|
|
|
|
## 调试技巧
|
|
|
|
### 日志查看
|
|
```bash
|
|
# 查看实时日志
|
|
tail -f logs/codeplay-*.log
|
|
```
|
|
|
|
### API 测试
|
|
使用 Swagger UI: http://localhost:5000/swagger
|
|
|
|
### 前端调试
|
|
使用浏览器开发者工具的 Vue Devtools
|
|
|
|
## 提交代码
|
|
|
|
```bash
|
|
# 1. 确保测试通过
|
|
dotnet test
|
|
|
|
# 2. 格式化代码
|
|
dotnet format
|
|
|
|
# 3. 提交
|
|
git add .
|
|
git commit -m "feat: description"
|
|
git push
|
|
```
|
|
|
|
## 发布 NuGet 包
|
|
|
|
```bash
|
|
# 1. 更新版本号
|
|
# 编辑 CodePlay.Core.csproj 中的 <Version>
|
|
|
|
# 2. 打包
|
|
dotnet pack CodePlay.Core/CodePlay.Core.csproj -c Release
|
|
|
|
# 3. 发布
|
|
dotnet nuget push CodePlay.Core.1.0.0.nupkg \
|
|
--source "https://api.nuget.org/v3/index.json" \
|
|
--api-key YOUR_API_KEY
|
|
```
|
|
|
|
## Docker 部署
|
|
|
|
```bash
|
|
# 构建镜像
|
|
docker build -t codeplay:latest .
|
|
|
|
# 运行
|
|
docker run -d -p 5000:80 codeplay:latest
|
|
```
|