多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

中國最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2

json教程

  • 關于 JSON
  • JSON 教程

    json格式

    JSON解析

    JSON遍歷

    JSON調用

    JSON轉換

    JSON獲取

    JSON字符串

    JSON數組

    jquery中的ajax方法怎樣通過JSONP進行遠程調用

    閱讀 (2399)
    關于JSONP的概念和為什么要使用JSONP網上已經有很多教程,這一節主要演示下在JQUERY中的ajax方法怎樣通過JSONP進行遠程調用 


    首先介紹下$.ajax的參數: 

    type:請求方式 GET/POST 
    url:請求地址 
    async:布爾類型,默認為true 表示請求是否為異步,如果為false表示為同步。 
    dataType:返回的數據類型 
    jsonp:傳遞給請求處理程序或頁面的,用以獲得jsonp回調函數名的參數名(一般默認為:callback) 
    jsonpCallback:自定義的jsonp回調函數名稱,默認為jQuery自動生成的隨機函數名,也可以寫"?",jQuery會自動為你處理數據 
    success:調用成功執行的函數 

    error:異常處理函數 


    1.示例1 

    服務器端我們采用MVC的ACTION來返回數據 
    代碼如下:
    public class HomeController : Controller 
    { 
      // 
      // GET: /Home/ 
    
      public ActionResult Index() 
      { 
      returnView(); 
      } 
    
      public ActionResult ReturnJson() 
      { 
      string callback = Request.QueryString["callback"]; 
      string json = "{'name':'張三','age':'20'}"; 
      string result = string.Format("{0}({1})", callback, json); 
      returnContent(result); 
      } 
    } 

    客戶端使用jsonp來傳輸數據 
    代碼如下:
    @{ ViewBag.Title = "Index"; Layout = "~/Views/Shared/_Layout.cshtml"; } 
    
    <script src="~/Scripts/jquery-1.7.1.min.js"type="text/javascript"> </script> 
    <script type="text/javascript"> 
    functionSendData() 
    { 
    $.ajax({ 
    type: "get", 
    async: false, 
    url: "/home/ReturnJson", 
    dataType: "jsonp", 
    success: function(data){ 
    alert(data.name); 
    }, 
    error: function(){ 
    alert('fail'); 
    } 
    }); 
    } 
    </script> 
    <input type="button" value="提交" onclick="SendData();"/> 
    點擊提交按鈕后,發現服務器端的Request.QueryString["callback"]返回一個隨機函數名。這樣就被設置成JSONP格式來傳遞數據了 

    2.自定義函數名 

    可以在傳遞過程中自定義函數名,只要使用jsonpCallback參數就可以了。 
    jsonp:表示傳遞的參數,默認為callback,我們也可以自定義,服務器段通過此參數,獲取自定義的函數名稱,服務器這樣獲取 Request.QueryString["callback"] 
    jsonpCallback表示傳遞的參數值,也就是回調的函數名稱,這是自定義的名稱。 

    代碼如下:
    <script type="text/javascript"> 
    functionSendData() { 
    $.ajax({ 
    type: "get", 
    async: false, 
    url: "/home/ReturnJson", 
    dataType: "jsonp", 
    jsonp: "callback",//傳遞給請求處理程序或頁面的,用以獲得jsonp回調函數名的參數名(一般默認為:callback) 
    jsonpCallback: "receive",//自定義的jsonp回調函數名稱,默認為jQuery自動生成的隨機函數名,也可以寫"?",jQuery會自動為你處理數據 
    success: function(data) { 
    alert(data.name); 
    }, 
    error: function() { 
    alert('fail'); 
    } 
    }); 
    } 
    
    functionreceive(data) { 
    alert(data.age); 
    } 
    </script> 

    jQuery AJAX實現調用頁面后臺方法

    Add1: 使用AJAX訪問aspx頁面和asmx使用方法是一樣的,區別在于aspx頁面中的方法必須為靜態方法,而asmx不需要.

    1.新建demo.aspx頁面。
    2.首先在該頁面的后臺文件demos.aspx.cs中添加引用。

    using System.Web.Services;

    3.無參數的方法調用.

    大家注意了,這個版本不能低于.net framework 2.0。2.0已下不支持的。后臺代碼:

    [WebMethod]     
    public static string SayHello()     
    {     
    //一定是要靜態方法,并且聲明為[WebMethod] 前端才可以訪問
    return "Hello Ajax!";       


    JS代碼:

    $(function() {     
        $("#btnOK").click(function() {     
            $.ajax({     
                //要用post方式      
                type: "Post",     
                //方法所在頁面和方法名      
                url: "Demo.aspx/SayHello",    
                //沒有參數也一定要傳一個空參數
                data: "{}",   
                contentType: "application/json; charset=utf-8",     
                dataType: "json",     
                success: function(data) {     
                    //返回的數據用data.d獲取內容      
                    alert(data.d);     
                },     
                error: function(err) {     
                    alert(err);     
                }     
            });     
        
            //禁用按鈕的提交      
            return false;     
        });     
    });    

    頁面代碼:

    <form id="form1" runat="server">
        <div>
            <%--<asp:Button ID="btnOK" runat="server" Text="驗證用戶" />--%>
             <%--因為是異步,所以只能使用html,上面的服務器控件是錯誤的 可以測試下--%>
            <input    id="btnOK" type="button" value="button" /> 
        </div>
    </form>
    

    運行效果如下:

    ajax

    3.有參數方法調用后臺代碼:

    [WebMethod]     
    public static string GetStr(string str, string str2)     
    {     
        return str + str2;     
    } 

    JS代碼:

    $(function() {     
        $("#btnOK").click(function() {     
            $.ajax({     
                type: "Post",     
                url: "demo.aspx/GetStr",     
                //方法傳參的寫法一定要對,str為形參的名字,str2為第二個形參的名字      
                data: "{'str':'我是','str2':'XXX'}",     
                contentType: "application/json; charset=utf-8",     
                dataType: "json",     
                success: function(data) {     
                    //返回的數據用data.d獲取內容      
                      alert(data.d);     
                },     
                error: function(err) {     
                    alert(err);     
                }     
            });     
        
            //禁用按鈕的提交      
            return false;     
        });     
    });    

    運行效果如下:

    w3c

    4.返回數組方法
    后臺代碼:

    [WebMethod]     
    public static List<string> GetArray()     
    {     
        List<string> li = new List<string>();     
        
        for (int i = 0; i < 10; i++)     
            li.Add(i + "");     
        
        return li;     
    }    

    JS代碼:

    $(function() {     
        $("#btnOK").click(function() {     
            $.ajax({     
                type: "Post",     
                url: "demo.aspx/GetArray",     
                contentType: "application/json; charset=utf-8",     
                dataType: "json",     
                success: function(data) {     
                    //插入前先清空ul      
                    $("#list").html("");     
        
                    //遞歸獲取數據      
                    $(data.d).each(function() {     
                        //插入結果到li里面      
                        $("#list").append("<li>" + this + "</li>");     
                    });     
        
                    alert(data.d);     
                },     
                error: function(err) {     
                    alert(err);     
                }     
            });     
        
            //禁用按鈕的提交      
            return false;     
        });     
    }); 

    頁面代碼:

    <form id="form1" runat="server">
    <div>
        <asp:Button ID="btnOK" runat="server" Text="驗證用戶" />
    </div>
    <ul id="list">
    </ul>
    </form>

    運行結果圖:

    jquery

    下面是Jquery中AJAX參數詳細列表:

    參數名類型描述
    urlString(默認: 當前頁地址) 發送請求的地址。
    typeString(默認: "GET") 請求方式 ("POST" 或 "GET"), 默認為 "GET"。注意:其它 HTTP 請求方法,如 PUT 和 DELETE 也可以使用,但僅部分瀏覽器支持。
    timeoutNumber設置請求超時時間(毫秒)。此設置將覆蓋全局設置。
    asyncBoolean(默認: true) 默認設置下,所有請求均為異步請求。如果需要發送同步請求,請將此選項設置為 false。注意,同步請求將鎖住瀏覽器,用戶其它操作必須等待請求完成才可以執行。
    beforeSendFunction發送請求前可修改 XMLHttpRequest 對象的函數,如添加自定義 HTTP 頭。XMLHttpRequest 對象是唯一的參數。
    function (XMLHttpRequest) {
      this; // the options for this ajax request
    }
    cacheBoolean(默認: true) jQuery 1.2 新功能,設置為 false 將不會從瀏覽器緩存中加載請求信息。
    completeFunction請求完成后回調函數 (請求成功或失敗時均調用)。參數: XMLHttpRequest 對象,成功信息字符串。
    function (XMLHttpRequest, textStatus) {
      this; // the options for this ajax request
    }
    contentTypeString(默認: "application/x-www-form-urlencoded") 發送信息至服務器時內容編碼類型。默認值適合大多數應用場合。
    dataObject,
    String
    發 送到服務器的數據。將自動轉換為請求字符串格式。GET 請求中將附加在 URL 后。查看 processData 選項說明以禁止此自動轉換。必須為 Key/Value 格式。如果為數組,jQuery 將自動為不同值對應同一個名稱。如 {foo:["bar1", "bar2"]} 轉換為 '&foo=bar1&foo=bar2'。
    dataTypeString

    預期服務器返回的數據類型。如果不指定,jQuery 將自動根據 HTTP 包 MIME 信息返回 responseXML 或 responseText,并作為回調函數參數傳遞,可用值:

    "xml": 返回 XML 文檔,可用 jQuery 處理。

    "html": 返回純文本 HTML 信息;包含 script 元素。

    "script": 返回純文本 JavaScript 代碼。不會自動緩存結果。

    "json": 返回 JSON 數據 。

    "jsonp": JSONP 格式。使用 JSONP 形式調用函數時,如 "myurl?callback=?" jQuery 將自動替換 ? 為正確的函數名,以執行回調函數。

    errorFunction(默認: 自動判斷 (xml 或 html)) 請求失敗時將調用此方法。這個方法有三個參數:XMLHttpRequest 對象,錯誤信息,(可能)捕獲的錯誤對象。
    function (XMLHttpRequest, textStatus, errorThrown) {
      // 通常情況下textStatus和errorThown只有其中一個有值 
      this; // the options for this ajax request
    }
    globalBoolean(默認: true) 是否觸發全局 AJAX 事件。設置為 false 將不會觸發全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用于控制不同的Ajax事件
    ifModifiedBoolean(默認: false) 僅在服務器數據改變時獲取新數據。使用 HTTP 包 Last-Modified 頭信息判斷。
    processDataBoolean(默認: true) 默認情況下,發送的數據將被轉換為對象(技術上講并非字符串) 以配合默認內容類型 "application/x-www-form-urlencoded"。如果要發送 DOM 樹信息或其它不希望轉換的信息,請設置為 false。
    successFunction請求成功后回調函數。這個方法有兩個參數:服務器返回數據,返回狀態
    function (data, textStatus) {
      // data could be xmlDoc, jsonObj, html, text, etc...
      this; // the options for this ajax request
    }

     

    代碼:

    $(document).ready(function() {
                jQuery("#clearCac").click(function() {
                    jQuery.ajax({
                        url: "/Handle/Do.aspx",
                        type: "post",
                        data: { id: '0' },
                        dataType: "json",
                        success: function(msg) {
                            alert(msg);
                        },
                        error: function(XMLHttpRequest, textStatus, errorThrown) {
                            alert(XMLHttpRequest.status);
                            alert(XMLHttpRequest.readyState);
                            alert(textStatus);
                        },
                        complete: function(XMLHttpRequest, textStatus) {
                            this; // 調用本次AJAX請求時傳遞的options參數
                        }
                    });
                });
            });
    

     

    一、error:function (XMLHttpRequest, textStatus, errorThrown) { } 
    (默 認: 自動判斷 (xml 或 html)) 請求失敗時調用時間。參數有以下三個:XMLHttpRequest 對象、錯誤信息、(可選)捕獲的錯誤對象。如果發生了錯誤,錯誤信息(第二個參數)除了得到null之外,還可能是"timeout", "error", "notmodified" 和 "parsererror"。

    textStatus:

     "timeout", "error", "notmodified" 和 "parsererror"。


    二、error事件返回的第一個參數XMLHttpRequest有一些有用的信息:

    XMLHttpRequest.readyState:

    狀態碼 

    0 - (未初始化)還沒有調用send()方法 

    1 - (載入)已調用send()方法,正在發送請求 

    2 - (載入完成)send()方法執行完成,已經接收到全部響應內容 

    3 - (交互)正在解析響應內容 

    4 - (完成)響應內容解析完成,可以在客戶端調用了


    三、data:"{}", data為空也一定要傳"{}";不然返回的是xml格式的。并提示parsererror.


    四、parsererror的異常和Header 類型也有關系。及編碼header('Content-type: text/html; charset=utf8');


    五、XMLHttpRequest.status:
    1xx-信息提示  
    這些狀態代碼表示臨時的響應。客戶端在收到常規響應之前,應準備接收一個或多個1xx響應。  
    100-繼續。  
    101-切換協議。  
    2xx-成功  
    這類狀態代碼表明服務器成功地接受了客戶端請求。  
    200-確定。客戶端請求已成功。  
    201-已創建。  
    202-已接受。  
    203-非權威性信息。  
    204-無內容。  
    205-重置內容。  
    206-部分內容。  
    3xx-重定向  
    客戶端瀏覽器必須采取更多操作來實現請求。例如,瀏覽器可能不得不請求服務器上的不同的頁面,或通過代理服務器重復該請求。  
    301-對象已永久移走,即永久重定向。  
    302-對象已臨時移動。  
    304-未修改。  
    307-臨時重定向。  
    4xx-客戶端錯誤  
    發生錯誤,客戶端似乎有問題。例如,客戶端請求不存在的頁面,客戶端未提供有效的身份驗證信息。400-錯誤的請求。  
    401-訪問被拒絕。IIS定義了許多不同的401錯誤,它們指明更為具體的錯誤原因。這些具體的錯誤代碼在瀏覽器中顯示,但不在IIS日志中顯示:  
    401.1-登錄失敗。  
    401.2-服務器配置導致登錄失敗。  
    401.3-由于ACL對資源的限制而未獲得授權。  
    401.4-篩選器授權失敗。  
    401.5-ISAPI/CGI應用程序授權失敗。  
    401.7–訪問被Web服務器上的URL授權策略拒絕。這個錯誤代碼為IIS6.0所專用。  
    403-禁止訪問:IIS定義了許多不同的403錯誤,它們指明更為具體的錯誤原因:  
    403.1-執行訪問被禁止。  
    403.2-讀訪問被禁止。  
    403.3-寫訪問被禁止。  
    403.4-要求SSL。  
    403.5-要求SSL128。  
    403.6-IP地址被拒絕。  
    403.7-要求客戶端證書。  
    403.8-站點訪問被拒絕。  
    403.9-用戶數過多。  
    403.10-配置無效。  
    403.11-密碼更改。  
    403.12-拒絕訪問映射表。  
    403.13-客戶端證書被吊銷。  
    403.14-拒絕目錄列表。  
    403.15-超出客戶端訪問許可。  
    403.16-客戶端證書不受信任或無效。  
    403.17-客戶端證書已過期或尚未生效。  
    403.18-在當前的應用程序池中不能執行所請求的URL。這個錯誤代碼為IIS6.0所專用。  
    403.19-不能為這個應用程序池中的客戶端執行CGI。這個錯誤代碼為IIS6.0所專用。  
    403.20-Passport登錄失敗。這個錯誤代碼為IIS6.0所專用。  
    404-未找到。  
    404.0-(無)–沒有找到文件或目錄。  
    404.1-無法在所請求的端口上訪問Web站點。  
    404.2-Web服務擴展鎖定策略阻止本請求。  
    404.3-MIME映射策略阻止本請求。  
    405-用來訪問本頁面的HTTP謂詞不被允許(方法不被允許)  
    406-客戶端瀏覽器不接受所請求頁面的MIME類型。  
    407-要求進行代理身份驗證。  
    412-前提條件失敗。  
    413–請求實體太大。  
    414-請求URI太長。  
    415–不支持的媒體類型。  
    416–所請求的范圍無法滿足。  
    417–執行失敗。  
    423–鎖定的錯誤。  
    5xx-服務器錯誤  
    服務器由于遇到錯誤而不能完成該請求。  
    500-內部服務器錯誤。  
    500.12-應用程序正忙于在Web服務器上重新啟動。  
    500.13-Web服務器太忙。  
    500.15-不允許直接請求Global.asa。  
    500.16–UNC授權憑據不正確。這個錯誤代碼為IIS6.0所專用。  
    500.18–URL授權存儲不能打開。這個錯誤代碼為IIS6.0所專用。  
    500.100-內部ASP錯誤。  
    501-頁眉值指定了未實現的配置。  
    502-Web服務器用作網關或代理服務器時收到了無效響應。  
    502.1-CGI應用程序超時。  
    502.2-CGI應用程序出錯。application.  
    503-服務不可用。這個錯誤代碼為IIS6.0所專用。  
    504-網關超時。  
    505-HTTP版本不受支持。  
    FTP  
    1xx-肯定的初步答復  
    這些狀態代碼指示一項操作已經成功開始,但客戶端希望在繼續操作新命令前得到另一個答復。  
    110重新啟動標記答復。  
    120服務已就緒,在nnn分鐘后開始。  
    125數據連接已打開,正在開始傳輸。  
    150文件狀態正常,準備打開數據連接。  
    2xx-肯定的完成答復  
    一項操作已經成功完成??蛻舳丝梢詧绦行旅睢?00命令確定。  
    202未執行命令,站點上的命令過多。  
    211系統狀態,或系統幫助答復。  
    212目錄狀態。  
    213文件狀態。  
    214幫助消息。  
    215NAME系統類型,其中,NAME是AssignedNumbers文檔中所列的正式系統名稱。  
    220服務就緒,可以執行新用戶的請求。  
    221服務關閉控制連接。如果適當,請注銷。  
    225數據連接打開,沒有進行中的傳輸。  
    226關閉數據連接。請求的文件操作已成功(例如,傳輸文件或放棄文件)。  
    227進入被動模式(h1,h2,h3,h4,p1,p2)。  
    230用戶已登錄,繼續進行。  
    250請求的文件操作正確,已完成。  
    257已創建“PATHNAME”。  
    3xx-肯定的中間答復  
    該命令已成功,但服務器需要更多來自客戶端的信息以完成對請求的處理。331用戶名正確,需要密碼。  
    332需要登錄帳戶。  
    350請求的文件操作正在等待進一步的信息。  
    4xx-瞬態否定的完成答復  
    該命令不成功,但錯誤是暫時的。如果客戶端重試命令,可能會執行成功。421服務不可用,正在關閉控制連接。如果服務確定它必須關閉,將向任何命令發送這一應答。  
    425無法打開數據連接。  
    426Connectionclosed;transferaborted.  
    450未執行請求的文件操作。文件不可用(例如,文件繁忙)。  
    451請求的操作異常終止:正在處理本地錯誤。  
    452未執行請求的操作。系統存儲空間不夠。  
    5xx-永久性否定的完成答復  
    該命令不成功,錯誤是永久性的。如果客戶端重試命令,將再次出現同樣的錯誤。500語法錯誤,命令無法識別。這可能包括諸如命令行太長之類的錯誤。  
    501在參數中有語法錯誤。  
    502未執行命令。  
    503錯誤的命令序列。  
    504未執行該參數的命令。  
    530未登錄。  
    532存儲文件需要帳戶。  
    550未執行請求的操作。文件不可用(例如,未找到文件,沒有訪問權限)。  
    551請求的操作異常終止:未知的頁面類型。  
    552請求的文件操作異常終止:超出存儲分配(對于當前目錄或數據集)。  
    553未執行請求的操作。不允許的文件名。  
    常見的FTP狀態代碼及其原因  
    150-FTP使用兩個端口:21用于發送命令,20用于發送數據。狀態代碼150表示服務器準備在端口20上打開新連接,發送一些數據。  
    226-命令在端口20上打開數據連接以執行操作,如傳輸文件。該操作成功完成,數據連接已關閉。  
    230-客戶端發送正確的密碼后,顯示該狀態代碼。它表示用戶已成功登錄。  
    331-客戶端發送用戶名后,顯示該狀態代碼。無論所提供的用戶名是否為系統中的有效帳戶,都將顯示該狀態代碼。  
    426-命令打開數據連接以執行操作,但該操作已被取消,數據連接已關閉。  
    530-該狀態代碼表示用戶無法登錄,因為用戶名和密碼組合無效。如果使用某個用戶帳戶登錄,可能鍵入錯誤的用戶名或密碼,也可能選擇只允許匿名訪問。如果使用匿名帳戶登錄,IIS的配置可能拒絕匿名訪問。  
    550-命令未被執行,因為指定的文件不可用。例如,要GET的文件并不存在,或試圖將文件PUT到您沒有寫入權限的目錄。


    關閉
    程序員人生
    主站蜘蛛池模板: 欧美亚洲国产精品久久久久 | 黄色的视频网站在线观看 | 午夜在线视频 | 国产视频一区在线 | 国产亚洲精品久久综合影院 | 国产欧美精品一区二区三区 | 377p欧洲最大胆艺术 | 日本不卡视频在线视频观看 | 国产一级精品高清一级毛片 | 亚洲精品一区二区三区中文字幕 | 激情视频在线观看免费 | 最新更新国内自拍视频 | 久久大香伊焦在人线免费 | 色婷婷91 | 精品国产理论在线观看不卡 | 国内精品久久国产 | 亚洲精品国产成人99久久 | 欧美xxxxhd高清极品 | 婷婷夜夜躁天天躁人人躁 | 91国内精品久久久久免费影院 | 久久 精品 一区二区 | 另类一区 | 国产妖精视频 | 国产老肥熟xxxx | 69xxxx女人免费 | 特级aa一级欧美毛片 | 精品久久久久久中文字幕专区 | 免费精品在线观看 | 岛国性视频播放免费视频 | 亚洲一区日韩二区欧美三区 | 国产精品卡哇伊小可爱在线观看 | 国产亚洲精品九九久在线观看 | 亚洲综合影视 | 美国一级特级毛片片aa视频 | 18在线网站 | 欧美毛片免费观看 | 日本免费不卡视频一区二区三区 | 国内精品久久久久久久亚洲 | 日韩中文字幕在线观看 | 综合图区亚洲欧美另类小说 | 欧美日韩一区二区视频免费看 |