[Core] .NET Core & VS Code 之路(2) Web API
开发Core项目的条件
看到VS包的体积,以及不想往下走了.
幸亏,ms出了VS Code,可开发.NET Core项目.实际上记事本也能写Core代码,但是开发是需要调试的.
所以本系列将持续用VS Code开发.以代码为主,关键点会加以注释
由于公司事比较多,一直没来得及更新
目录
Web API
- dotnet new 添加Core项目
- project.json添加依赖
-
"Microsoft.AspNetCore.Server.Kestrel"
-
"Microsoft.AspNetCore.Mvc"
-
- 添加Startup.cs
- 添加ValuesController.cs
- 修改Program.cs
project.json 添加的依赖
1 2 3 4 | "dependencies" : { "Microsoft.AspNetCore.Server.Kestrel" : "1.0.0" , //webhost "Microsoft.AspNetCore.Mvc" : "1.0.0" //webapi mvc } |
添加的Startup.cs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | using Microsoft.AspNetCore.Builder; using Microsoft.Extensions.DependencyInjection; public class Startup { public void Configure(IApplicationBuilder app) { app.UseMvc(); //使用MVC管道 } public void ConfigureServices(IServiceCollection services) { services.AddMvc(); //MVC加入到DI容器中 } } |
添加的ValuesController.cs
1 2 3 4 5 6 7 8 9 10 11 | using Microsoft.AspNetCore.Mvc; public class ValuesController { [HttpGet( "/values/{name}" )] //name参数注入 public string Index( string name) { return "Hello World:" + name; } } |
修改的Program.cs
1 2 3 4 5 6 7 8 9 | public static void Main( string [] args) { new WebHostBuilder() .UseKestrel() .UseStartup<Startup>() .UseUrls( "http://localhost:8899" , "http://localhost:9988/" )//同时监听2个端口 .Build() .Run(); } |
MVC
在.NET Core中,MVC和Web API实际上走的同一个管道
本例子会在上面的Web API基础上修改
- 添加和修改project.json
- Microsoft.AspNetCore.Razor.Tools
- 添加HomeController
- 添加Index.cshtml
- 修改Program.cs
MVC中因为有razor动态编译,所以不仅仅添加1个依赖即可
project.json修改的内容
1 2 3 4 5 6 7 8 9 10 11 12 13 | "buildOptions" : { "debugType" : "portable" , "emitEntryPoint" : true , "preserveCompilationContext" : true //动态编译 }, "dependencies" : { "Microsoft.AspNetCore.Server.Kestrel" : "1.0.0" , //webhost "Microsoft.AspNetCore.Mvc" : "1.0.0" , //webapi mvc "Microsoft.AspNetCore.Razor.Tools" : { //mvc razor "version" : "1.0.0-preview2-final" , "type" : "build" } }, |
添加的HomeController.cs
注意:需要继承Controller类
1 2 3 4 5 6 7 8 9 10 11 | using Microsoft.AspNetCore.Mvc; public class HomeController : Controller { [HttpGet( "/{name}" )] public IActionResult Index( string name) { ViewBag.Name = "Hello " + name; return View(); } } |
添加Index.cshtml
目录结构和之前方式(ASP.NET MVC)一样
1 2 3 4 5 6 7 8 9 10 | <!DOCTYPE html> <html lang= "zh" > <head> <meta charset= "UTF-8" > <title>Title</title> </head> <body> <h1>@ViewBag.Name</h1> </body> </html> |
修改Program.cs
1 2 3 4 5 6 7 8 9 10 | public static void Main( string [] args) { new WebHostBuilder() .UseKestrel() .UseStartup<Startup>() .UseContentRoot(Directory.GetCurrentDirectory()) //mvc views需要 .UseUrls( "http://localhost:8899" , "http://localhost:9988/" )//同时监听2个端口 .Build() .Run(); } |
静态文件
- 添加依赖:project.json
- Microsoft.AspNetCore.StaticFiles
- 注册管道:Startup.cs
- 添加静态文件:wwwroot
project.json
1 2 3 4 5 6 7 8 9 | "dependencies" : { //nuget包 "Microsoft.AspNetCore.Mvc" : "1.0.0" , //webapi mvc "Microsoft.AspNetCore.Server.Kestrel" : "1.0.0" , //webhost "Microsoft.AspNetCore.Razor.Tools" : { //mvc razor "version" : "1.0.0-preview2-final" , "type" : "build" }, "Microsoft.AspNetCore.StaticFiles" : "1.0.0" //静态文件 }, |
注册管道
1 2 3 4 5 | public void Configure(IApplicationBuilder app) { app.UseStaticFiles(); //需要在mvc前 否则将优先被mvc路由匹配执行 app.UseMvc(); } |
添加静态文件
静态文件默认是以wwwroot文件夹为根目录
注意:
- 添加依赖后,需要Restore后才能使用该库
- 本节由于篇幅问题,去除了配置文件的大量说明
- 本文地址:http://www.cnblogs.com/neverc/p/5801210.html
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 如果觉得还有帮助的话,可以点一下右下角的【推荐】,希望能够持续的为大家带来好的技术文章!想跟我一起进步么?那就【关注】我吧。
分类:
[17]Core
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义