在开发.NET Web Api并部署到IIS服务器时,很多开发者可能会遇到一个问题:当尝试执行PUT或DELETE请求时,服务器返回HTTP Error 405.0 - Method Not Allowed错误。这个问题让不少开发者头疼不已,但其实解决起来并不复杂。
重点来了:IIS默认情况下出于安全考虑,仅支持GET、POST、HEAD和调试方法,而不支持PUT和DELETE操作。这是因为PUT和DELETE方法具有修改和删除数据的能力,如果未正确配置和保护,可能会带来潜在的安全风险。
为了解决这个问题,我们需要在Web.config文件中进行一些配置调整。具体步骤如下:
-
打开Web.config文件:在项目的根目录下找到Web.config文件。
-
修改system.webServer配置:在
<system.webServer>
节点下,我们需要做两件事:- 移除WebDAVModule:WebDAV(Web-based Distributed Authoring and Versioning)是IIS用于支持Web上直接编辑和管理文件的扩展,但它可能会干扰PUT和DELETE请求。因此,我们需要移除它。
- 配置无扩展名URL处理程序:我们需要为无扩展名的URL添加处理程序,并允许PUT和DELETE方法。
具体配置如下:
<system.webServer> <modules runAllManagedModulesForAllRequests="true"> <remove name="WebDAVModule"/> </modules> <handlers> <remove name="WebDAV"/> <remove name="ExtensionlessUrlHandler-ISAPI-4.0_32bit"/> <remove name="ExtensionlessUrlHandler-ISAPI-4.0_64bit"/> <remove name="ExtensionlessUrlHandler-Integrated-4.0"/> <add name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness32" responseBufferLimit="0"/> <add name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework64\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness64" responseBufferLimit="0"/> <add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0"/> </handlers> </system.webServer>
通过上述配置,IIS将能够支持.NET Web Api的PUT和DELETE请求,从而解决返回405错误的问题。
总之,遇到IIS不支持PUT和DELETE请求的问题时,不要慌张,按照上述步骤在Web.config文件中进行相应配置即可。这样,你的.NET Web Api应用就能更加灵活地处理各种HTTP请求了。