Ermöglichen der ursprungsübergreifenden Ressourcenfreigabe auf IIS7: Ein umfassender Leitfaden
Einführung
Cross -Origin Resource Sharing (CORS) ermöglicht das Abrufen und Nutzen von Ressourcen aus einer Domäne durch Anwendungen eines anderen Ursprungs. Um CORS auf IIS7 zu aktivieren, befolgen Sie diese Schritte:
Konfiguration
Benutzerdefinierte Header hinzufügen:
<customHeaders> <add name="Access-Control-Allow-Origin" value="*" /> <add name="Access-Control-Allow-Methods" value="GET,PUT,POST,DELETE,OPTIONS" /> <add name="Access-Control-Allow-Headers" value="Content-Type" /> </customHeaders>
Fehlerbehebung
Wenn Sie trotz der Konfiguration immer noch eine 405-Antwort erhalten, kann dies daran liegen IIS7s Umgang mit HTTP-OPTIONEN.
Option 1: IIS7-Handlerzuordnungen ändern
Setzen Sie die ausführbare Datei auf:
%windir%\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll
Option 2: OPTIONS-Verb im Code behandeln
Überschreiben Sie die BeginRequest-Methode in Ihrem Anwendungscode:
protected void Application_BeginRequest(object sender,EventArgs e) { HttpContext.Current.Response.AddHeader("Access-Control-Allow-Origin", "*"); if(HttpContext.Current.Request.HttpMethod == "OPTIONS") { // Handle pre-flight OPTIONS call from browser 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(); } }
Fazit
Die Aktivierung von CORS auf IIS7 erfordert sowohl Konfigurationsaktualisierungen als auch potenzielle Fehlerbehebung. Indem Sie die oben beschriebenen Schritte befolgen, können Sie ursprungsübergreifende Interaktionen mit Zuversicht ermöglichen.
Das obige ist der detaillierte Inhalt vonSo aktivieren Sie Cross-Origin Resource Sharing (CORS) auf IIS7: Eine Schritt-für-Schritt-Anleitung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!