目录
一、Swagger简介
1.1-什么是Swagger?
1.2-Swagger有什么优势?
1.3-Swagger、OpenAPI3.0、Restful API的区别?
1.4-Swagger工具
1.5-Swagger UI工具主要功能
1.6-Swashbuckle组件
1.7-TPL
二、在ASP.NET Core Web API中使用Swagger UI
2.1-创建一个WebAPI项目
2.2-下载、安装、引入【Swashbuckle.AspNetCore】包
2.3-配置Swagger中间件(注册 Swagger 服务)
2.4-启用Swagger中间件
2.5-运行项目即可
2.6-如果想每次运行都默认直接到Swagger的页面
2.7-描述信息详细讲解
三、启用XML注释
四、实例
五、小知识点
5.1-当入参/出参返回object或者匿名类时,也需要加上注释怎么办?
5.2-如何隐藏接口:有接口但是不想让别人看到?
5.3-设置路由前缀/自定义头内容/网页标题
5.3-自定义首页
5.4-开启JWT认证
5.5-使用Cookie持久化存储Token,解决每次刷新需要重新输入Token授权
右击【解决方案】,然后点击【管理Nuget包】,搜索【Swashbuckle.AspNetCore】包,点击【安装】即可,博主这里下载的是【最新稳定版5.6.3】。
在【Startup.cs】文件中的【ConfigureService】类中引入命名空间,并注册Swagger服务并配置文档信息。
//引入命名空间 using Microsoft.OpenApi.Models; //注册Swagger services.AddSwaggerGen(u => { u.SwaggerDoc("v1", new Microsoft.OpenApi.Models.OpenApiInfo { Version = "Ver:1.0.0",//版本 Title = "xxx后台管理系统",//标题 Description = "xxx后台管理系统:包括人员信息、团队管理等。",//描述 Contact=new Microsoft.OpenApi.Models.OpenApiContact { Name="西瓜程序猿", Email="xxx@qq.com" } }); });
如果安装的 Swashbuckle.AspNetCore Nuget包版本<= 3.0.0,写法略有不同。将 【OpenApiInfo】 替换成 【Info】 即可。
services.AddSwaggerGen(x => { x.SwaggerDoc("v1", new Info() { Title = "Web Api", Version = "v1" }); });
在【Startup.cs】文件中的【Configure】类中启用Swagger中间件,为生成的JSON文档和SwaggerUI提供服务。
//启用Swagger中间件 app.UseSwagger(); //配置SwaggerUI app.UseSwaggerUI(u => { u.SwaggerEndpoint("/swagger/v1/swagger.json", "WebAPI_v1"); });
2.5.1-如果我们直接运行项目,会出现这样的界面,说明我们的Web API程序没有问题。
2.5.2-然后我们在地址栏中输入【swagger/v1/swagger.json】。
可以看到浏览器出现这样的界面,如果出现这样的界面,说明Swagger也没有问题。
注意:按照2.5.1在地址栏中的【swagger/v1/swagger.json】需要与在【Startup.cs】文件中的【Configure】类中启用Swagger中间件添加的代码保持一致,因为这段代码就是自动生成JSON文件的,你配置的路径和JSON文件地址是什么,就在浏览器中输入对应的即可。
2.5.1-以上步骤都没问题的话,然后我们地址栏中输入【swagger/index.html】。
如果能出现以下界面,说明SwaggerUI也没有问题,都全部正常了。
2.6.1-打开【launchSettings.json】这个文件。
2.6.2-然后将【launchUrl】的值从【weatherforecast】修改成【swagger】。
2.6.3-然后运行项目就直接进入Swagger首页了。
3.1-双击解决方案
3-2-然后进入这个页面,加上这个代码
true $(NoWarn);1591
3-3.在【Startup.cs】文件中的【ConfigureService】类中注册读取XML信息的Swagger。
#region 读取xml信息 // 使用反射获取xml文件,并构造出文件的路径 var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml"; var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile); // 启用xml注释,该方法第二个参数启用控制器的注释,默认为false. u.IncludeXmlComments(xmlPath, true); #endregion
注意:
4.1-写一个实例:在【WeatherForecastController】控制器中写一个方法。
4.2-写上以下代码然后进行请求。
////// 这是一个例子 /// ////// 描述:这是一个带参数的GET请求 /// Web API /// /// 主键ID ///测试字符串 [HttpGet("{id}")] public ActionResultGet(int id) { return $"你请求的ID是:{id}"; }
4.3-可以看到【XML注释】起作用了,然后调用也成功了。
(1)在方法中加上以下特性:
[ProducesResponseType(typeof(xxx),200)]
(2)在Remarks节点下进行注释:
在需要进行隐藏的接口上加上以下特性即可:
[ApiExplorerSettings(IgnoreApi =true)]
如果不想加上"swagger",而输入5000即可访问,也可以自定义路由前缀,加上以下代码即可。
(1)新建一个【index.html】,右击该文件,点击【属性】,进行设置相关操作。
(2)在Startup.cs进行配置。
(3)静态页面下载地址:
Swagger UI
(1)在Startup.cs进行配置。
#region 开启JWT u.OperationFilter(); u.AddSecurityDefinition("oauth2", new Microsoft.OpenApi.Models.OpenApiSecurityScheme { Description = "JWT授权(数据将在请求头中进行传输)直接在下框中输入Bearer { token } (注意两者之间是一个空格) ", Name = "Authorization", In = Microsoft.OpenApi.Models.ParameterLocation.Header,//jwt默认存放Authorazation信息的位置(请求头中) Type = Microsoft.OpenApi.Models.SecuritySchemeType.ApiKey }); #endregion
(2)下载包,注意版本号问题,尽量保持一致,不然会报错。
(3)然后将接口加上权限,去请求该接口,可以看到请求头中会有以下信息了。
下载相关资源。可以访问下载(如果失效了,请联系我[西瓜程序猿])。
下载地址(编码:yRLCRp81):https://yongteng.lanzoub.com/iG3Be16ayltc
密码:anum
目录结构:
(1)在【index.html】文件导入abp.js/swagger.js文件。
(2)在【swagger.js】里面需要注意请求授权地址。
(3)后端授权逻辑。
版权声明:本文为原创文章,版权归 [西瓜程序猿] 所有,转载请注明出处,有任何疑问请私信咨询。
原文链接:.NET Core WebAPI中使用Swagger(完整教程)_西瓜程序猿的博客-CSDN博客