IIS下網站對options請求直接返回404

来源:https://www.cnblogs.com/cplemom/archive/2019/05/10/10845434.html
-Advertisement-
Play Games

什麼是options請求 options請求為發送非簡單跨域請求前的預檢請求,若該請求未正常返回,瀏覽器會阻止後續的請求發送。 一般情況下,有三種方式會導致瀏覽器發起預檢請求 1.請求的方法不是GET/HEAD/POST 2.POST請求的Content Type並非application/x ww ...


什麼是options請求

options請求為發送非簡單跨域請求前的預檢請求,若該請求未正常返回,瀏覽器會阻止後續的請求發送。
一般情況下,有三種方式會導致瀏覽器發起預檢請求

1.請求的方法不是GET/HEAD/POST
2.POST請求的Content-Type並非application/x-www-form-urlencoded, multipart/form-data 或 text/plain
3.請求中設置了自定義的header欄位(如Token)

瀏覽器發出請求但直接返回404

若未對iis進行配置,則會導致options請求被iis直接響應返回,而不會進入到代碼中。這也是Global中的Application_BeginRequest無法捕獲到options請求的原因。

1.檢查webconfig中的配置,是否移除了對options請求的特殊處理
可在iis中進行配置:[網站]-[應用程式]-[處理程式映射]

<system.webServer>
  <handlers>
    <remove name="OPTIONSVerbHandler" />
  </handlers>
</system.webServer>

2.檢查iis伺服器是否安裝了UrlScan,若安裝了請檢查AllowVerbs中是否包含了options
可在iis中查看是否安裝了UrlScan [網站]-[ISAPI篩選器] (可以找到UrlScan安裝路徑)
image

UrlScan的配置文件為UrlScan.ini (C:\Windows\System32\inetsrv\urlscan\UrlScan.ini)
將OPTIONS從[DenyVerbs]中移除並添加到[AllowVerbs]下

3.在Global的Application_BeginRequest實踐中直接響應options請求

//允許所有的options請求,直接返回200狀態碼
private void Application_BeginRequest(object sender, EventArgs e)
{
    if (HttpContext.Current.Request.HttpMethod == "OPTIONS")
    {
        HttpContext.Current.Response.StatusCode = 200;
        HttpContext.Current.Response.Headers["Access-Control-Allow-Origin"] = HttpContext.Current.Request.Headers["origin"];
        HttpContext.Current.Response.End();
    }
}

4.在webconfig中的Allow-Method中添加上options

<system.webServer>
    <httpProtocol>
      <customHeaders>
        <add name="Access-Control-Allow-Methods" value="OPTIONS,POST,GET" />
        <add name="Access-Control-Allow-Headers" value="x-requested-with,aspxauth" />
        <add name="Access-Control-Allow-Credentials" value="true" />
      </customHeaders>
    </httpProtocol>
</system.webServer>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 5.10自我總結 1.編碼解碼 1.字元串編碼 字元 》翻譯過程 》數字 2.字元串解碼 字元 》翻譯過程 》數字 3.編碼解碼用到的翻譯工具 中國:GBK 外國:日本—Shift_JIS,美國ASCII,南韓Euc kr 國際統一:Unicode進行編寫,存取用UTF 8,Unicode與UTF ...
  • 一個業務模塊,是負責完成一系列功能的,這些功能相互之間具有密切的關聯性,所以對於一個模塊來說,業務服務是一個整體,不應把他們再按單個實體拆分開來。OSharp 的業務模塊代碼結構設計,也是根據這一原則來設計的。設計規則如下 ...
  • 1.數字分隔符(Digit Separators ) 數字分隔符使代碼更具可讀性。在聲明變數時,可以將_添加到單獨的數字中。編譯器只刪除_。以下代碼片段在C#7中看起來更具可讀性: In C# 6 In C# 7 In C# 7.2 2.二進位(Binary Literals ) C#7為二進位文件 ...
  • 如果你有一臺Linux伺服器(CentOS7+ 或者 Ubuntu 16.04+)可以使用以下命令快速搭建一個博客。 ...
  • 當月第一天0時0分0秒DateTime.Now.AddDays(1 - DateTime.Now.Day).Date當月最後一天23時59分59秒DateTime.Now.AddDays(1 - DateTime.Now.Day).Date.AddMonths(1).AddSeconds(-1)取當... ...
  • 上一篇博客已經完成 C#ModBus Tcp Master的實現 本篇主要對不同的功能碼所發出的報文進行解析(包括請求報文及響應報文) 讀操作 功能碼 0x01 讀一組線圈 讀取站號為1 從地址12開始的10個線圈 測試結果 上一篇博客已經總結了讀操作報文格式,就按照格式劃分 報文解析: 註意:報文 ...
  • wpf 模擬抖音很火的羅盤時鐘,附源碼 前端時間突然發現,抖音火了個壁紙,就是黑底蕾絲~~~ 錯錯錯,黑底白字的羅盤時鐘! 作為程式員的我,也覺得很新穎,所以想空了研究下,這不,空下來了就用wpf,寫個屬於.net自己的羅盤時鐘,目前只實現了時分秒,農曆日期等邏輯都是一樣的,所以就略了,有興趣的朋友 ...
  • 簡介 主要是採用identity Server4 和ocelot 加上consul 實現簡單的客戶端模式 開發準備 環境準備 下載並安裝Consul具體請參考前幾篇的內容 項目介紹 創建ocelotServerTest項目 創建IdentityServer4Test項目 創建consulServer ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...