清空web.api项目,安装Microsoft.aspnet.webapi.cors 5.2.3,添加
config.EnableCors();
到webapiconfig。制作控制器和行动
public class HomeController : ApiController
{
[EnableCors("*" , "*" , "*")]
public async Task<string> Get()
{
return await Task.FromResult("omg");
}
}
调试应用并加载fiddler并向http://localhost:61939/api/Home
发出请求没有CORS标头。 web.config包含:
<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>
我错过了什么?为什么这不会在我的Get方法的所有请求中插入Access-Control-Allow-Origin标头?
在web.config中定义CORS的答案也不是答案......在某些时候我需要添加原始检查,甚至可能需要检查HTTP方法:
if(requestContext.HttpMethod == "POST" && (origin == "https://someplace.com" || origin == "http://localhost"))