Asp.Net Core 5 WebAPI發布后的Swagger不顯示問題


.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=".\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-->


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM