首页 > Windows开发 > 详细

Asp.Net Core 5 WebAPI发布后的Swagger不显示问题

时间:2021-01-26 22:56:33      阅读:534      评论:0      收藏:0      [点我收藏+]

.Net 5在创建Web API时可以直接选择Swagger,在调试的时候没有问题,在发布后发现打不开swagger。

只需要把Startup.cs中的Configure方法改一下就好了。

 
技术分享图片
 

改成

 
技术分享图片
 

之前的代码会判断在开发环境中才加载,移出去之后就都可以加载Swagger了。



作者:尼尔丶
链接:https://www.jianshu.com/p/cf22dffacec4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
 
 
 

只需要把Startup.cs中的Configure方法改一下就好了。

 
技术分享图片
 

改成

 
技术分享图片
 

之前的代码会判断在开发环境中才加载,移出去之后就都可以加载Swagger了。



作者:尼尔丶
链接:https://www.jianshu.com/p/cf22dffacec4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
 
 
 

.NetCore swagger发布到iis时访问api出现404的解决方案

 

介绍
使用netcore作为纯后端提供api已经变得越来越频繁,swagger也成为很多人的选择。通常会在代码中限制ASPNETCORE_ENVIRONMENT为Production时关闭swagger。但是往往我们需要将api发布到本地iis调试或供他人使用时,swagger将会被禁止。发布后项目往往默认为Production环境,将其修改为Development即可解决。

解决方法
打开发布到iis的文件夹下的web.config文件,添加以下代码:

1 <environmentVariables>
2 <environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
3 </environmentVariables>

修改后的web.config结构大致如下:

技术分享图片
 1 <?xml version="1.0" encoding="utf-8"?>
 2 <configuration>
 3 <location path="." inheritInChildApplications="false">
 4 <system.webServer>
 5 <handlers>
 6 <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
 7 </handlers>
 8 <aspNetCore processPath="dotnet" arguments="*.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" hostingModel="InProcess">
 9 <environmentVariables>
10 <environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
11 </environmentVariables>
12 </aspNetCore>
13 </system.webServer>
14 </location>
15 </configuration>
16 <!--ProjectGuid: 15af0485-b65a-422a-bf12-5877b85abb6c-->

Asp.Net Core 5 WebAPI发布后的Swagger不显示问题

原文:https://www.cnblogs.com/cxxtreasure/p/14332484.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!