iis swagger 部署_Asp.netCore WebApi初体验之搭建Swagger并在IIS上部署

1、新建.netCore webapi项目

dfeb8c6c597421d3089c24d5e30f8dcc.png

2、安装swagger ,通过 Package Manager 控制台:

5145adadcf2d16db340fdf3298a5cb1b.png

3、Startup.cs中注册服务并添加至管道

1 usingSystem;2 usingSystem.Collections.Generic;3 usingSystem.Linq;4 usingSystem.Threading.Tasks;5 usingMicrosoft.AspNetCore.Builder;6 usingMicrosoft.AspNetCore.Hosting;7 usingMicrosoft.AspNetCore.HttpsPolicy;8 usingMicrosoft.AspNetCore.Mvc;9 usingMicrosoft.Extensions.Configuration;10 usingMicrosoft.Extensions.DependencyInjection;11 usingMicrosoft.Extensions.Logging;12 usingMicrosoft.Extensions.Options;13

14 namespaceCoreTest15 {16 public classStartup17 {18 publicStartup(IConfiguration configuration)19 {20 Configuration =configuration;21 }22 public IConfiguration Configuration { get; }23 //This method gets called by the runtime. Use this method to add services to the container.

24 public voidConfigureServices(IServiceCollection services)25 {26 services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);27

28 //1、注册服务Swagger

29 services.AddSwaggerGen(options =>

30 {31 options.SwaggerDoc("v1", newSwashbuckle.AspNetCore.Swagger.Info32 {33 Version = "v1",34 Title = "My API",35 Description = "by JiaJia"

36 });37 });38 }39 //This method gets called by the runtime. Use this method to configure the HTTP request pipeline.

40 public voidConfigure(IApplicationBuilder app, IHostingEnvironment env)41 {42 if(env.IsDevelopment())43 {44 app.UseDeveloperExceptionPage();45 }46 else

47 {48 app.UseHsts();49 }50 app.UseHttpsRedirection();51 app.UseMvc();52

53 //2、添加到管道

54 #if DEBUG

55 app.UseSwagger();56 app.UseSwaggerUI(c =>

57 {58 c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");59 //c.DocExpansion(DocExpansion.None);

60 });61 #endif

62 }63 }64 }

4、访问 Swagger UI 地址

http://localhost:60238/swagger/index.html

40a994ecd8c577b6ee54aaee1509ef45.png

5、添加备注

1)在项目属性的 生成 => 输出 中勾选 XML文档文件。

943dabf7959a0e0d9a214c77a659a734.png

2)在 Start.cs => ConfigureServices 方法中的 AddSwaggerGen 处增加 IncludeXmlComments 处理。

1 //1、注册服务Swagger

2 services.AddSwaggerGen(options =>

3 {4 options.SwaggerDoc("v1", newSwashbuckle.AspNetCore.Swagger.Info5 {6 Version = "v1",7 Title = "My API",8 Description = "by JiaJia"

9 });10 //在 Start.cs => ConfigureServices 方法中的 AddSwaggerGen 处增加 IncludeXmlComments 处理。

11 options.IncludeXmlComments(string.Format("{0}/CoreTest.xml",12 AppDomain.CurrentDomain.BaseDirectory));13

14 /*或者这种添加方式//为 Swagger JSON and UI设置xml文档注释路径15 var basePath = Path.GetDirectoryName(typeof(Program).Assembly.Location);//获取应用程序所在目录(绝对,不受工作目录影响,建议采用此方法获取路径)16 var xmlPath = Path.Combine(basePath, "CoreTest.xml");//和项目名对应17 options.IncludeXmlComments(xmlPath);*/

18 });

3)控制器对Action添加注释信息

1 ///

2 ///根据ID获取用户信息3 ///

4 /// 用户ID

5 /// 用户信息

6 [HttpGet("{id}")]7 public ActionResult Get(intid)8 {9 return "user info";10 }

4)(指定输出路径默认空白,需要填写:bin\Debug\),而且默认的(CoreTest.xml)xml文件,与Startup的文件必须对应(否则会报错)

f3cd58a365c253c7215a2033e70ddc1f.png

5)不想每一个方法都这么加注释,可以这么配置(对当前项目进行配置,可以忽略警告,记得在后边加上分号 ;1591)

c9ce942f93ef19c345cd310ee27e8cf0.png

74dce67ee6384b8ec1ecd254ec00ed6f.png

最终效果:

dea8be53867e102455a05ba77b01143c.png

二、接口执行时间分析——MiniProfiler

搭建MiniProfiler

安装引入nuget包:

Install-Package MiniProfiler.AspNetCore.Mvc

e7b27db06e495695a69c487e869269b8.png

然后,在startup.cs 中配置服务ConfigureServices:

1 //注册服务MiniProfiler

2 services.AddMiniProfiler(options =>

3 {4 options.RouteBasePath = "/profiler";//注意这个路径要和下边 index.html 脚本配置中的一致,

5 (options.Storage as MemoryCacheStorage).CacheDuration = TimeSpan.FromMinutes(10);6 });

3、最后,调用下中间件即可:

1 //调用MiniProfiler中间件

2 app.UseMiniProfiler();

在 Swagger 中配置 MiniProfiler

上边我们在配置中已经启动了服务,接下来就需要设置如何在 swagger 中展示了,这个时候我们就需要自定义我们的swagger主页了,以前我们是用的默认的index.html,现在咱们需要自定义一个:

1

2

3

4

5

6

%(DocumentTitle)

7

8

9

10

11

12

13

14

15 html{

16 box-sizing:border-box;

17 overflow:-moz-scrollbars-vertical;

18 overflow-y:scroll;

19 }

20

21 *,22 *:before,23 *:after{

24 box-sizing:inherit;

25 }

26

27 body{

28 margin:0;

29 background:#fafafa;

30 }

31

32 %(HeadContent)33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
IIS部署ASP.NET Core Web API项目及Swagger可以按照以下步骤进行: 1. 首先,我们需要确保已经在本地系统上安装了ASP.NET Core Runtime和ASP.NET Core Hosting Bundle,以便在IIS中运行ASP.NET Core应用程序。 2. 在Visual Studio中,打开你的ASP.NET Core Web API项目。确保项目已经设置为IIS Express作为本地开发服务器。 3. 在项目根目录下的`Properties`文件夹中找到`launchsettings.json`文件,检查并确保该文件中已经配置了`applicationUrl`为`http://localhost:{port}/`,其中`port`为你希望的端口号。 4. 在Visual Studio的顶部菜单中,找到 `Build` -> `Publish {YourProjectName}`,选择发布目标为`Folder`,点击 `Publish`。 5. 在弹出的窗口中选择一个输出文件夹,用于存储发布项目的文件。 6. 打开发布文件夹,在该文件夹中应该有一个名为`web.config`的文件。双击打开该文件,确保其中有以下代码片段: ```xml <aspNetCore processPath="dotnet" arguments=".\{YourProjectName}.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false" /> ``` 7. 打开IIS管理器,右键点击`Sites`节点,选择`Add Website`。填写网站名称以及物理路径为刚刚发布项目的目录。 8. 对于应用程序池,选择一个合适的.NET CLR版本和托管管道模式(例如:.NET CLR版本为No Managed Code,托管管道模式为集成)。 9. 在网站的右侧,找到`Authentication`,禁用匿名身份验证并启用Windows身份验证。 10. 重新启动IIS。 11. 现在,我们可以在浏览器中访问`http://localhost:{port}`,应该能够看到你的ASP.NET Core Web API已经在IIS上成功部署。 12. 最后,要在部署的项目中添加Swagger,可以通过NuGet包管理器,添加`Swashbuckle.AspNetCore`包。 13. 在`Startup.cs`文件的`ConfigureServices`方法中,添加以下配置: ```csharp services.AddSwaggerGen(c => { c.SwaggerDoc("v1", new OpenApiInfo { Title = "API", Version = "v1" }); }); ``` 14. 在`Startup.cs`文件的`Configure`方法中,添加以下代码: ```csharp app.UseSwagger(); app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "API v1"); }); ``` 15. 重新发布并重新启动IIS,现在你的ASP.NET Core Web API应该在IIS部署并且通过Swagger可以浏览和调用你的API接口。 以上就是在IIS部署ASP.NET Core Web API项目及Swagger的步骤。请注意,确保按照正确的顺序执行每一步,并根据自己的项目配置进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值