下载
查看当前dotnet版本
dotnet --version
查看所有
dotnet --info
.NET Core SDKs installed:
2.1.509 [C:\Program Files\dotnet\sdk]2.2.402 [C:\Program Files\dotnet\sdk]
3.0.100 [C:\Program Files\dotnet\sdk]
下载 .net 3.1 SDK
基础知识
教学视频
项目的目录如下:
API
--Startup.cs
--Program.cs
--Controllers
--API.csproj
--appsetting.json--......
Application 应用层
client-app 前台
Domain 模型层
Persistence 用于访问数据层的中间层
启动顺序
Program.cs => main() =>CreateHostBuilder=>Startup.cs
配置整个.Net Core应用,然后运行,默认使用appsetting.json中的配置内容
Startup类
Startup.ConfigureServices 方法
文档:
服务是应用使用的组件 。 例如,日志记录组件就是一项服务。 将配置(或注册)服务的代码添加到 Startup.ConfigureServices 方法中,比如配置Kersal 外部应用服务器
先调用configureService方法再调用configure方法
ConfigureService负责配置依赖注入
向IOC容器中注册服务(类)
#添加不包含RazorView的MVC服务(IOC容器中的类)
services.AddControllerWithViews();
#只添加Controller,通常用作Restful的API
services.AddController();
Configure方法
ASP.NET Core pipeline
在ASP.NET Core管道中处理HTTP请求的东西叫做中间件(MiddleWare)
比如MVC框架
#判断是否是开发模式
if (env.IsDevelopment())
{
#使用中间件,没有捕获的异常会展示在页面上
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}
#转化HTTP请求为HTTPS请求,强制使用SSL层
app.UseHttpsRedirection();
#使用静态文件服务
app.UseStaticFiles();
#路由中间件,在2.0的.net Core中Routing是和MVC集成的,在3里面单独提取出来了
app.UseRouting();
app.UseAuthorization();
#路由映射的方法,使用lamda表达式
app.UseEndpoints(endpoints =>
{
#使用RazorPages的路由
endpoints.MapRazorPages();
#使用MVC的路由
// endpoints.MapControllerRoute("default", "{controller=home}/{action=index}/{id?}");
});
端点(endpoint)
端点就是进来的HTTP请求URL结尾的部分,这部分会被中间件处理
可以使用路由表的形式或者在Controller中使用attribute来进行路由匹配
中间件注册的顺序就是http请求处理的顺序
启动配置
配置文件
/properties/launchSettings.json
{
"iisSettings": {
"windowsAuthentication": false,
"anonymousAuthentication": true,
"iisExpress": {
"applicationUrl": "http://localhost:40882",
"sslPort": 44349
}
},
"profiles": {
"IIS Express": {
"commandName": "IISExpress",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"aspnetcoreapp": {
"commandName": "Project",
"launchBrowser": true,
"applicationUrl": "https://localhost:5001;http://localhost:5000",
#环境变量
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
}
}
也可以在Startup.cs中添加ConfigureDevelopment方法来实现不同的逻辑,同理ConfigureServices
,也可以修改Startup类为StartupDevelopment类
同时修改Program.cs
webBuilder.UseStartup<Startup>()
为
webBuilder.UseStartup(typeof(Program))
使用程序集
包管理
服务器端
nuget
前端
npm
开始迁移
-
修改global.json
-
修改项目文件,去除不必要的引用
启动更改
文档地址将
IHostingEnvironment
替换为IWebHostEnvironment
并为 Microsoft.Extensions.Hosting 命名空间添加using
语句-
因为只使用了WebAPI,所以修改AddMvc为AddControllers,同样的修改
UseMvc为UseEndpoints,路由采用默认的路由
注意如果使用UseCors的话必须要保证这个使用这个服务的组件在他的后面注册
运行dotnet restore 更新程序包依赖,没有报错
运行dotnet build 没有报错
-
运行dotnet watch run 报错
大概意思是没有在使用endpoints之前使用路由
加上 app.UseRouting();,再次run
-
没有报错,访问下试试
搞定