"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > IIS7에서 CORS를 활성화할 때 405 메서드가 허용되지 않음 응답을 받는 이유는 무엇입니까?

IIS7에서 CORS를 활성화할 때 405 메서드가 허용되지 않음 응답을 받는 이유는 무엇입니까?

2024년 12월 23일에 게시됨
검색:395

Why Am I Getting a 405 Method Not Allowed Response When Enabling CORS on IIS7?

IIS7에서 CORS(Cross-Origin Resource Sharing) 활성화

IIS7에서 CORS를 활성화하는 것은 어려운 작업일 수 있으며, 특히 예상치 못한 문제가 발생할 경우 더욱 그렇습니다. 200 응답 이전의 405 응답과 같은 동작. 이 문서의 목적은 이 문제를 조명하고 효과적인 솔루션을 제공하는 것입니다.

405 응답 해결

IIS7이 HTTP 옵션을 가로챌 때 405 메서드가 허용되지 않음 응답이 발생할 수 있습니다. 귀하의 신청서 대신 요청하십시오. 이 문제를 해결하려면:

  1. IIS7의 처리기 매핑 섹션으로 이동합니다.
  2. "OPTIONSVerbHandler" 항목을 찾습니다.
  3. "ProtocolSupportModule" 설정을 "IsapiHandler"로 변경합니다. ."
  4. 실행 파일을 다음으로 설정 "%windir%\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll."

대체 솔루션: BeginRequest에서 OPTIONS 동사 처리

If 위 단계로 문제가 해결되지 않으면 BeginRequest 메서드에서 HTTP OPTIONS 동사를 다음과 같이 처리할 수 있습니다. 다음:

protected void Application_BeginRequest(object sender, EventArgs e)
{
    HttpContext.Current.Response.AddHeader("Access-Control-Allow-Origin", "*");

    if (HttpContext.Current.Request.HttpMethod == "OPTIONS")
    {
        // Pre-flight OPTIONS call
        HttpContext.Current.Response.AddHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");
        HttpContext.Current.Response.AddHeader("Access-Control-Allow-Headers", "Content-Type, Accept");
        HttpContext.Current.Response.AddHeader("Access-Control-Max-Age", "1728000");
        HttpContext.Current.Response.End();
    }
}
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3