首頁 >後端開發 >php教程 >實例詳解ajax跨域訪問報錯501的解決方法

實例詳解ajax跨域訪問報錯501的解決方法

小云云
小云云原創
2018-01-08 16:23:001868瀏覽

本文主要為大家詳細介紹了ajax跨域訪問報錯501的解決方法,具有一定的參考價值,有興趣的小伙伴們可以參考一下,希望能幫助到大家。

問題:ajax跨域存取報錯501

運行下面的程式碼會報錯501

$.ajax({
      type: "POST",
    url: "http://192.168.1.202/sensordata.php",

    contentType:'application/json; charset=utf-8',
    data: JSON.stringify(ajaxPostData),
    dataType:'json',
    success: function(data){
      //On ajax success do this
      console.info("success.");
      if (data["status"] == "ok"){
        alert("Settings is Ok. The Machine is rebooting.");
      }
    },
    error: function(xhr, ajaxOptions, thrownError) {
      //On error do this
      console.info("error.");
      if (xhr.status == 200) {

        alert(ajaxOptions);
      }
      else {
        alert(xhr.status);
        alert(thrownError);
      }
    }
  });

解決方法:

去掉contentType:'application/json ; charset=utf-8'

#原因:

1 在跨網域的時候,除了contentType為application/x-www-form-urlencoded, multipart/form-data或text/plain外,都會觸發瀏覽器先發送方法為OPTIONS的請求。

2 例如說,你原來的請求是方法方法POST,如果第一個請求回傳的結果Header中的Allow屬性並沒有POST方法,

3那麼第二個請求是不會發送的,此時瀏覽器控制台會報錯,告訴你POST方法並不被伺服器支援。

相關推薦:

Ajax跨域的完美解決方案實例分享

ajax跨域請求下parsererror的錯誤解決方法

JS實作Ajax跨域請求flask回應內容

#

以上是實例詳解ajax跨域訪問報錯501的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn