1
我有一個使用API應用程序部署到Azure的ASP.net WebApi。要從最佳實踐的神祕列表中檢查另一個項目,我想從所有HTTP請求(x-powered-by,server,x-aspnet-version)中刪除標準服務器標頭。我的web.config位於下面,根據配置建議hereAzure API應用程序刪除標準服務器標頭
如果將我的應用程序部署到Azure Web App,則會成功刪除標頭。但是,它似乎重複向Azure API發佈相同的部署。APP不遵循標準的web.config配置,因此上述標題仍然存在於所有http請求中。
有誰知道這是不是還沒有得到支持,或者如果有一種替代方式做到這一點?我只能認爲網關或其他設備不尊重刪除。
<configuration>
<system.web>
<compilation debug="true" targetFramework="4.5.2" />
<httpRuntime enableVersionHeader="false" />
</system.web>
<system.webServer>
<handlers>
<remove name="ExtensionlessUrlHandler-Integrated-4.0" />
<remove name="OPTIONSVerbHandler" />
<remove name="TRACEVerbHandler" />
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />
</handlers>
<security>
<requestFiltering removeServerHeader ="true"></requestFiltering>
</security>
<httpProtocol>
<customHeaders>
<clear />
<remove name="X-Powered-By"/>
</customHeaders>
</httpProtocol>
</system.webServer>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="Newtonsoft.Json" culture="neutral" publicKeyToken="30ad4fe6b2a6aeed" />
<bindingRedirect oldVersion="0.0.0.0-7.0.0.0" newVersion="7.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Net.Http.Formatting" publicKeyToken="31bf3856ad364e35" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-5.2.3.0" newVersion="5.2.3.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Web.Http" publicKeyToken="31bf3856ad364e35" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-5.2.3.0" newVersion="5.2.3.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
</configuration>
嗨@Mohit我給了這個嘗試,編輯網關的web.config與上面通過KUDO發佈的一樣,但是當通過Fiddler查看請求時,標準頭文件仍然存在。我打算使用一些特定的API應用程序功能,因此,如果可能的話,我正在嘗試使用API應用程序而不是Web應用程序。 – BMac