前言:
.net 6 LTS版本发布已经有若干天了。此处做一个关于使用.net 6 开发精简版webapi(minimal api)的入门教程,以及VS2022 上面的两个强大的新技能(热重载、代码自动反编译)的顺带演示。
1、新建一个项目。此处就命名为 SomeExample:
![](https://i-blog.csdnimg.cn/blog_migrate/9133c5013be9c15774094f6c7315bb67.png)
2、选择 .net6版本,并且此处先去掉HTTPS配置以及去掉使用控制器的选项:
![](https://i-blog.csdnimg.cn/blog_migrate/f6db38262872d840f249ab3e4c6c0db2.png)
3、创建完成以后,原始画面如下所示。并且,解决方案一栏只剩下program文件,其他文件都被精简掉了。并且没有Main函数入口和命名空间等。
![](https://i-blog.csdnimg.cn/blog_migrate/f5f9876110b7d88a724c0fc4e3d56cea.png)
4、接下来开始做几个简单的webapi方法案例。先删掉原有的,替换为自定义的来个webapi方法,一个Get,一个Post。具体代码如下图所示。
![](https://i-blog.csdnimg.cn/blog_migrate/3186899b92a1f67cc43d7cc00165b857.png)
5、运行以后,会打开自带的swagger页面。大佬们可以自行比对代码部分和swagger部分的一些特点。
![](https://i-blog.csdnimg.cn/blog_migrate/3dbfbb901927c0114e0ea0e08427f869.png)
6、执行HelloWorld这个Get方法的执行结果,如下图所示。
![](https://i-blog.csdnimg.cn/blog_migrate/82eb7e4cd686ab9db8c91a6d93b47849.png)
7、执行HelloMiniApi这个Post方法的执行结果,如下图所示。
![](https://i-blog.csdnimg.cn/blog_migrate/493d1573904a6e3ba71147d9b15ab5d2.png)
8、Api根据不同的用途,在swagger展示上面,咱们还可以对它进行一些分类。分类通过设置Tags标签来实现,具体设置内容:在方法的末尾设置WithTags,里面指定分类的显示的名称。运行以后的swagger展示效果和有关代码,如下图所示。
![](https://i-blog.csdnimg.cn/blog_migrate/e5fc32c132f73b13a0e98f32b214c976.png)
9、对api方法进行分代码文件管理。如果API方法很多,全写在program里面也不现实。所以下面做个拓展。新建用于测试使用的静态类 TestService,并且实现一个静态方法 TestApi。其中,方法的参数必须是 this WebApplication。然后就可以通过传入的参数,来拓展实现webapi,例如此处新增一个ServiceApi的api方法,以及有关其他实现,如下图所示。
![](https://i-blog.csdnimg.cn/blog_migrate/1d9d3d1ab1dff3532f6be0d7f59a7b71.png)
10、新增拓展的api以后,需要在program文件里面引用使用,详细内容如下图所示。
![](https://i-blog.csdnimg.cn/blog_migrate/175354608652f2146d42fe09f567c192.png)
11、运行以后的swagger展示图。
![](https://i-blog.csdnimg.cn/blog_migrate/b7882795fcc48bf3f2c62cf91dce3c54.png)
12、测试下执行结果,返回预期结果,说明测试成功。
![](https://i-blog.csdnimg.cn/blog_migrate/f4a1c649f7510cda09d44f03236cf36a.png)
13、测试下VS 2022热重载的功能,在返回值里面进行修改,然后点击热重载小火苗按钮进行热更新。
![](https://i-blog.csdnimg.cn/blog_migrate/a8e1bbe2e1a2ed41e4228dd49c7ad86c.png)
14、热更新以后,不需要重新编译,直接在swagger展示页对刚才设置的api方法进行调用,调用结果如下图所示,说明热重载更新成功。将来遇到需要调试的代码时候,大佬们都可以很方便地进行热更新,无需重新编译,可以大大提高效率。
![](https://i-blog.csdnimg.cn/blog_migrate/0979f874a407f42274c860e79c708c24.png)
15、接下来是依赖注入的验证测试。新增一个测试服务类 TestDependencyInjection,具体实现内容如图所示。
![](https://i-blog.csdnimg.cn/blog_migrate/d365cc3cb1a49aeaa8aa74796143654f.png)
16、TestDependencyInjection对应的接口 ITestDependencyInjection内容:
![](https://i-blog.csdnimg.cn/blog_migrate/3b7aebe41d45b4617f209242c4d16e95.png)
17、在program文件里面,对上面的服务进行注册。此处注册一个单例实例,具体代码如下图展示。
![](https://i-blog.csdnimg.cn/blog_migrate/675fd9cc94c2ae0d117809f9a47aef23.png)
18、接下来是验证依赖注入是否成功。此处我在ServiceApi这个webapi方法里面进行注入。注入需要注意事项:在webapi方法的委托类型的参数里面,第一个参数必须是HttpContext;然后后面是自己的参数,此处是注入服务的接口。并且在api方法里面调用了show方法进行验证。
![](https://i-blog.csdnimg.cn/blog_migrate/6a40f831d083016206a8412f918556b3.png)
19、运行程序,在swagger展示页面点击执行对应的webapi方法,并查看结果。如下图所示,输出show方法里面的内容,代表依赖注入成功。
![](https://i-blog.csdnimg.cn/blog_migrate/d56da464e3cca328ac2933d741d2a5e5.png)
20、再扩展个VS2022的隐藏技能:引用的第三方或者nuget包时候(不限制.net 版本),在对应的封装的类或者方法上面,按F12,可以直接进入到反编译以后的代码里面去,可以看到封装的源码。例如此处以UseSwagger为例,在此处按F12进去瞅瞅究竟。
![](https://i-blog.csdnimg.cn/blog_migrate/35abef8601633d04fda7ca88ab1b4ebf.png)
21、正常情况下咱们应该F12进去只能看见属性名称、方法名称,看不到具体实现。而现在是可以看到具体实现的代码的。如下图所示,方法里面的具体代码都有,也可以继续进一步F12去看底层的代码。
![](https://i-blog.csdnimg.cn/blog_migrate/bfa7a8e7632f6f6f48be8eded5a5b7c2.png)
以上就是该篇博客的全部内容,欢迎大佬们留言、推荐或点赞,或者一起谈人生。祝各位大佬们,玩.net 6玩的开心~~
本文链接:https://www.cnblogs.com/weskynet/p/15626899.html