.Net 5在创建Web API时可以直接选择Swagger,在调试的时候没有问题,在发布后发现打不开swagger。
只需要把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=".logsstdout" 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-->