面向 C# 初学者的完整教程

🧱 一、项目结构说明

你的项目大致结构如下:

复制代码
TaskManager/
├── backend/
│   ├── TaskManager.Core/           // 实体类和接口
│   ├── TaskManager.Infrastructure/ // 数据库、服务实现
│   └── TaskManager.API/            // Web API 入口(控制器 + Program.cs)
└── frontend/                       // React/Next.js 前端

✅ 二、安装依赖项

你需要先确保 .NET SDK 已安装:

1. 检查 .NET SDK 是否安装

bash 复制代码
dotnet --version

如果没有,请去官网下载并安装:https://dotnet.microsoft.com/en-us/download


2. 安装 Entity Framework Core 相关包(在项目目录执行)

bash 复制代码
# 进入 Infrastructure 项目目录
cd TaskManager.Infrastructure

# 安装数据库相关包(你使用的是 SQL Server)
dotnet add package Microsoft.EntityFrameworkCore
dotnet add package Microsoft.EntityFrameworkCore.SqlServer
dotnet add package Microsoft.EntityFrameworkCore.Tools
dotnet add package BCrypt.Net-Next     # 用户密码加密

# 如果你有 API 项目也需使用 EF Core 工具支持迁移
cd ../TaskManager.API
dotnet add package Microsoft.AspNetCore.Authentication.JwtBearer

🛠️ 三、构建项目

1. 回到根目录构建整个项目解决方案

bash 复制代码
cd D:\Users\gento\RiderProjects\TaskManager\backend
dotnet build

如果你已经在用 Rider 或 Visual Studio,也可以直接点击"Build"按钮。


🚀 四、数据库迁移与更新

你需要先根据实体类生成数据库表:

1. 创建数据库迁移(注意指定项目)

bash 复制代码
cd TaskManager.API
dotnet ef migrations add InitialCreate --project ../TaskManager.Infrastructure

2. 执行迁移,更新数据库

bash 复制代码
dotnet ef database update --project ../TaskManager.Infrastructure

🏃 五、运行 API 项目

运行 TaskManager.API 项目:

bash 复制代码
cd ../TaskManager.API
dotnet run

运行后你会看到:

bash 复制代码
Now listening on: http://localhost:5201

你可以用 Postman 或浏览器访问接口,例如:

  • http://localhost:5201/api/tasks
  • http://localhost:5201/api/auth/register

🧪 六、常见问题速查

问题 解决方法
localStorage 报错 typeof window !== 'undefined' 判断是否在浏览器环境
Token 报 401 检查是否正确设置 Bearer 头、是否数据库已更新并包含用户表
EF 报 Invalid object name 是数据库中表未创建成功,请重新执行迁移或检查连接字符串
DLL 被锁定,编译失败 关闭正在运行的 API(任务管理器或 Ctrl+C),然后重试构建

📌 七、建议的开发流程

  1. 每次修改实体类后,执行一次迁移:dotnet ef migrations add ...
  2. 每次迁移后更新数据库:dotnet ef database update
  3. 如果构建失败先 dotnet clean,然后 dotnet build
  4. 本地调试:先运行后端,再启动前端(Next.js)
相关推荐
dapeng28704 小时前
分布式系统容错设计
开发语言·c++·算法
qq_417695054 小时前
代码热修复技术
开发语言·c++·算法
badhope9 小时前
Mobile-Skills:移动端技能可视化的创新实践
开发语言·人工智能·git·智能手机·github
码云数智-园园10 小时前
微服务架构下的分布式事务:在一致性与可用性之间寻找平衡
开发语言
C++ 老炮儿的技术栈10 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++
hz_zhangrl10 小时前
CCF-GESP 等级考试 2026年3月认证C++一级真题解析
开发语言·c++·gesp·gesp2026年3月·gespc++一级
Liu6288810 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
IT猿手10 小时前
基于控制障碍函数的多无人机编队动态避障控制方法研究,MATLAB代码
开发语言·matlab·无人机·openclaw·多无人机动态避障路径规划·无人机编队
AI科技星11 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
sunwenjian88611 小时前
Java进阶——IO 流
java·开发语言·python