新聞中心
關(guān)于JSONP的概念以及為什么要使用JSONP您可以參考JSONP教程,本文的重點在于演示下在JQUERY中的Ajax方法怎樣通過JSONP進行遠程調(diào)用。

站在用戶的角度思考問題,與客戶深入溝通,找到通許網(wǎng)站設(shè)計與通許網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、申請域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋通許地區(qū)。
$.ajax的參數(shù)
首先介紹下$.ajax的參數(shù):
- type:請求方式 GET/POST
- url:請求地址
- async:布爾類型,默認(rèn)為true 表示請求是否為異步,如果為false表示為同步。
- dataType:返回的數(shù)據(jù)類型
- jsonp:傳遞給請求處理程序或頁面的,用以獲得jsonp回調(diào)函數(shù)名的參數(shù)名(一般默認(rèn)為:callback)
- jsonpCallback:自定義的jsonp回調(diào)函數(shù)名稱,默認(rèn)為jQuery自動生成的隨機函數(shù)名,也可以寫"?",jQuery會自動為你處理數(shù)據(jù)
- success:調(diào)用成功執(zhí)行的函數(shù)
- error:異常處理函數(shù)
1、示例1
服務(wù)器端我們采用MVC的ACTION來返回數(shù)據(jù)
代碼如下:
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來傳輸數(shù)據(jù)
代碼如下:
@{ ViewBag.Title = "Index"; Layout = "~/Views/Shared/_Layout.cshtml"; }
點擊提交按鈕后,發(fā)現(xiàn)服務(wù)器端的Request.QueryString["callback"]返回一個隨機函數(shù)名。這樣就被設(shè)置成JSONP格式來傳遞數(shù)據(jù)了
2.自定義函數(shù)名
可以在傳遞過程中自定義函數(shù)名,只要使用jsonpCallback參數(shù)就可以了。
- jsonp:表示傳遞的參數(shù),默認(rèn)為callback,我們也可以自定義,服務(wù)器段通過此參數(shù),獲取自定義的函數(shù)名稱,服務(wù)器這樣獲取 Request.QueryString["callback"]
- jsonpCallback:表示傳遞的參數(shù)值,也就是回調(diào)的函數(shù)名稱,這是自定義的名稱。
代碼如下:
jQuery AJAX實現(xiàn)調(diào)用頁面后臺方法
Add1: 使用AJAX訪問aspx頁面和asmx使用方法是一樣的,區(qū)別在于aspx頁面中的方法必須為靜態(tài)方法,而asmx不需要.
1.新建demo.aspx頁面。
2.首先在該頁面的后臺文件demos.aspx.cs中添加引用。
using System.Web.Services;
3.無參數(shù)的方法調(diào)用.
大家注意了,這個版本不能低于.net framework 2.0。2.0已下不支持的。后臺代碼:
[WebMethod]
public static string SayHello()
{
//一定是要靜態(tài)方法,并且聲明為[WebMethod] 前端才可以訪問
return "Hello Ajax!"; JS代碼:
$(function() {
$("#btnOK").click(function() {
$.ajax({
//要用post方式
type: "Post",
//方法所在頁面和方法名
url: "Demo.aspx/SayHello",
//沒有參數(shù)也一定要傳一個空參數(shù)
data: "{}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(data) {
//返回的數(shù)據(jù)用data.d獲取內(nèi)容
alert(data.d);
},
error: function(err) {
alert(err);
}
});
//禁用按鈕的提交
return false;
});
}); 頁面代碼:
運行效果如下:
3.有參數(shù)方法調(diào)用后臺代碼:
[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) {
//返回的數(shù)據(jù)用data.d獲取內(nèi)容
alert(data.d);
},
error: function(err) {
alert(err);
}
});
//禁用按鈕的提交
return false;
});
}); 運行效果如下:
4.返回數(shù)組方法
后臺代碼:
[WebMethod] public static ListGetArray() { List li = new List (); 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("");
//遞歸獲取數(shù)據(jù)
$(data.d).each(function() {
//插入結(jié)果到li里面
$("#list").append("頁面代碼:
運行結(jié)果圖:
下面是Jquery中AJAX參數(shù)詳細列表:
| 參數(shù)名 | 類型 | 描述 |
| url | String | (默認(rèn): 當(dāng)前頁地址) 發(fā)送請求的地址。 |
| type | String | (默認(rèn): "GET") 請求方式 ("POST" 或 "GET"), 默認(rèn)為 "GET"。注意:其它 HTTP 請求方法,如 PUT 和 DELETE 也可以使用,但僅部分瀏覽器支持。 |
| timeout | Number | 設(shè)置請求超時時間(毫秒)。此設(shè)置將覆蓋全局設(shè)置。 |
| async | Boolean | (默認(rèn): true) 默認(rèn)設(shè)置下,所有請求均為異步請求。如果需要發(fā)送同步請求,請將此選項設(shè)置為 false。注意,同步請求將鎖住瀏覽器,用戶其它操作必須等待請求完成才可以執(zhí)行。 |
| beforeSend | Function | 發(fā)送請求前可修改 XMLHttpRequest 對象的函數(shù),如添加自定義 HTTP 頭。XMLHttpRequest 對象是唯一的參數(shù)。
function (XMLHttpRequest) {
this; // the options for this ajax request
}
|
| cache | Boolean | (默認(rèn): true) jQuery 1.2 新功能,設(shè)置為 false 將不會從瀏覽器緩存中加載請求信息。 |
| complete | Function | 請求完成后回調(diào)函數(shù) (請求成功或失敗時均調(diào)用)。參數(shù): XMLHttpRequest 對象,成功信息字符串。
function (XMLHttpRequest, textStatus) {
this; // the options for this ajax request
}
|
| contentType | String | (默認(rèn): "application/x-www-form-urlencoded") 發(fā)送信息至服務(wù)器時內(nèi)容編碼類型。默認(rèn)值適合大多數(shù)應(yīng)用場合。 |
| data | Object, String | 發(fā) 送到服務(wù)器的數(shù)據(jù)。將自動轉(zhuǎn)換為請求字符串格式。GET 請求中將附加在 URL 后。查看 processData 選項說明以禁止此自動轉(zhuǎn)換。必須為 Key/Value 格式。如果為數(shù)組,jQuery 將自動為不同值對應(yīng)同一個名稱。如 {foo:["bar1", "bar2"]} 轉(zhuǎn)換為 '&foo=bar1&foo=bar2'。 |
| dataType | String |
預(yù)期服務(wù)器返回的數(shù)據(jù)類型。如果不指定,jQuery 將自動根據(jù) HTTP 包 MIME 信息返回 responseXML 或 responseText,并作為回調(diào)函數(shù)參數(shù)傳遞,可用值: "xml": 返回 XML 文檔,可用 jQuery 處理。 "html": 返回純文本 HTML 信息;包含 script 元素。 "script": 返回純文本 JavaScript 代碼。不會自動緩存結(jié)果。 "json": 返回 JSON 數(shù)據(jù) 。 "jsonp": JSONP 格式。使用 JSONP 形式調(diào)用函數(shù)時,如 "myurl?callback=?" jQuery 將自動替換 ? 為正確的函數(shù)名,以執(zhí)行回調(diào)函數(shù)。 |
| error | Function | (默認(rèn): 自動判斷 (xml 或 html)) 請求失敗時將調(diào)用此方法。這個方法有三個參數(shù):XMLHttpRequest 對象,錯誤信息,(可能)捕獲的錯誤對象。
function (XMLHttpRequest, textStatus, errorThrown) {
// 通常情況下textStatus和errorThown只有其中一個有值
this; // the options for this ajax request
}
|
| global | Boolean | (默認(rèn): true) 是否觸發(fā)全局 AJAX 事件。設(shè)置為 false 將不會觸發(fā)全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用于控制不同的Ajax事件 |
| ifModified | Boolean | (默認(rèn): false) 僅在服務(wù)器數(shù)據(jù)改變時獲取新數(shù)據(jù)。使用 HTTP 包 Last-Modified 頭信息判斷。 |
| processData | Boolean | (默認(rèn): true) 默認(rèn)情況下,發(fā)送的數(shù)據(jù)將被轉(zhuǎn)換為對象(技術(shù)上講并非字符串) 以配合默認(rèn)內(nèi)容類型 "application/x-www-form-urlencoded"。如果要發(fā)送 DOM 樹信息或其它不希望轉(zhuǎn)換的信息,請設(shè)置為 false。 |
| success | Function | 請求成功后回調(diào)函數(shù)。這個方法有兩個參數(shù):服務(wù)器返回數(shù)據(jù),返回狀態(tài)
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; // 調(diào)用本次AJAX請求時傳遞的options參數(shù)
}
});
});
});一、error:function (XMLHttpRequest, textStatus, errorThrown) { }
(默 認(rèn): 自動判斷 (xml 或 html)) 請求失敗時調(diào)用時間。參數(shù)有以下三個:XMLHttpRequest 對象、錯誤信息、(可選)捕獲的錯誤對象。如果發(fā)生了錯誤,錯誤信息(第二個參數(shù))除了得到null之外,還可能是"timeout", "error", "notmodified" 和 "parsererror"。
textStatus:
"timeout", "error", "notmodified" 和 "parsererror"。
二、error事件返回的第一個參數(shù)XMLHttpRequest有一些有用的信息:
XMLHttpRequest.readyState:
狀態(tài)碼
0 - (未初始化)還沒有調(diào)用send()方法
1 - (載入)已調(diào)用send()方法,正在發(fā)送請求
2 - (載入完成)send()方法執(zhí)行完成,已經(jīng)接收到全部響應(yīng)內(nèi)容
3 - (交互)正在解析響應(yīng)內(nèi)容
4 - (完成)響應(yīng)內(nèi)容解析完成,可以在客戶端調(diào)用了
三、data:"{}", data為空也一定要傳"{}";不然返回的是xml格式的。并提示parsererror.
四、parsererror的異常和Header 類型也有關(guān)系。及編碼header('Content-type: text/html; charset=utf8');
五、XMLHttpRequest.status:
- 1xx-信息提示
這些狀態(tài)代碼表示臨時的響應(yīng)。客戶端在收到常規(guī)響應(yīng)之前,應(yīng)準(zhǔn)備接收一個或多個1xx響應(yīng)。
- 100-繼續(xù)。
- 101-切換協(xié)議。
- 2xx-成功
這類狀態(tài)代碼表明服務(wù)器成功地接受了客戶端請求。
- 200-確定。客戶端請求已成功。
- 201-已創(chuàng)建。
- 202-已接受。
- 203-非權(quán)威性信息。
- 204-無內(nèi)容。
- 205-重置內(nèi)容。
- 206-部分內(nèi)容。
- 3xx-重定向
客戶端瀏覽器必須采取更多操作來實現(xiàn)請求。例如,瀏覽器可能不得不請求服務(wù)器上的不同的頁面,或通過代理服務(wù)器重復(fù)該請求。
- 301-對象已永久移走,即永久重定向。
- 302-對象已臨時移動。
- 304-未修改。
- 307-臨時重定向。
- 4xx-客戶端錯誤
發(fā)生錯誤,客戶端似乎有問題。例如,客戶端請求不存在的頁面,客戶端未提供有效的身份驗證信息。400-錯誤的請求。
- 401-訪問被拒絕。IIS定義了許多不同的401錯誤,它們指明更為具體的錯誤原因。這些具體的錯誤代碼在瀏覽器中顯示,但不在IIS日志中顯示:
- 401.1-登錄失敗。
- 401.2-服務(wù)器配置導(dǎo)致登錄失敗。
- 401.3-由于ACL對資源的限制而未獲得授權(quán)。
- 401.4-篩選器授權(quán)失敗。
- 401.5-ISAPI/CGI應(yīng)用程序授權(quán)失敗。
- 401.7–訪問被Web服務(wù)器上的URL授權(quán)策略拒絕。這個錯誤代碼為IIS6.0所專用。
- 403-禁止訪問:IIS定義了許多不同的403錯誤,它們指明更為具體的錯誤原因:
- 403.1-執(zhí)行訪問被禁止。
- 403.2-讀訪問被禁止。
- 403.3-寫訪問被禁止。
- 403.4-要求SSL。
- 403.5-要求SSL128。
- 403.6-IP地址被拒絕。
- 403.7-要求客戶端證書。
- 403.8-站點訪問被拒絕。
- 403.9-用戶數(shù)過多。
- 403.10-配置無效。
- 403.11-密碼更改。
- 403.12-拒絕訪問映射表。
- 403.13-客戶端證書被吊銷。
- 403.14-拒絕目錄列表。
- 403.15-超出客戶端訪問許可。
- 403.16-客戶端證書不受信任或無效。
- 403.17-客戶端證書已過期或尚未生效。
- 403.18-在當(dāng)前的應(yīng)用程序池中不能執(zhí)行所請求的URL。這個錯誤代碼為IIS6.0所專用。
- 403.19-不能為這個應(yīng)用程序池中的客戶端執(zhí)行CGI。這個錯誤代碼為IIS6.0所專用。
- 403.20-Passport登錄失敗。這個錯誤代碼為IIS6.0所專用。
- 404-未找到。
- 404.0-(無)–沒有找到文件或目錄。
- 404.1-無法在所請求的端口上訪問Web站點。
- 404.2-Web服務(wù)擴展鎖定策略阻止本請求。
- 404.3-MIME映射策略阻止本請求。
- 405-用來訪問本頁面的HTTP謂詞不被允許(方法不被允許)
- 406-客戶端瀏覽器不接受所請求頁面的MIME類型。
- 407-要求進行代理身份驗證。
- 412-前提條件失敗。
- 413–請求實體太大。
- 414-請求URI太長。
- 415–不支持的媒體類型。
- 416–所請求的范圍無法滿足。
- 417–執(zhí)行失敗。
- 423–鎖定的錯誤。
- 5xx-服務(wù)器錯誤
服務(wù)器由于遇到錯誤而不能完成該請求。
- 500-內(nèi)部服務(wù)器錯誤。
- 500.12-應(yīng)用程序正忙于在Web服務(wù)器上重新啟動。
- 500.13-Web服務(wù)器太忙。
- 500.15-不允許直接請求Global.asa。
- 500.16–UNC授權(quán)憑據(jù)不正確。這個錯誤代碼為IIS6.0所專用。
- 500.18–URL授權(quán)存儲不能打開。這個錯誤代碼為IIS6.0所專用。
- 500.100-內(nèi)部ASP錯誤。
- 501-頁眉值指定了未實現(xiàn)的配置。
- 502-Web服務(wù)器用作網(wǎng)關(guān)或代理服務(wù)器時收到了無效響應(yīng)。
- 502.1-CGI應(yīng)用程序超時。
- 502.2-CGI應(yīng)用程序出錯。application.
- 503-服務(wù)不可用。這個錯誤代碼為IIS6.0所專用。
- 504-網(wǎng)關(guān)超時。
- 505-HTTP版本不受支持。
FTP
- 1xx-肯定的初步答復(fù)
這些狀態(tài)代碼指示一項操作已經(jīng)成功開始,但客戶端希望在繼續(xù)操作新命令前得到另一個答復(fù)。
- 110重新啟動標(biāo)記答復(fù)。
- 120服務(wù)已就緒,在nnn分鐘后開始。
- 125數(shù)據(jù)連接已打開,正在開始傳輸。
- 150文件狀態(tài)正常,準(zhǔn)備打開數(shù)據(jù)連接。
- 2xx-肯定的完成答復(fù)
一項操作已經(jīng)成功完成??蛻舳丝梢詧?zhí)行新命令。200命令確定。
- 202未執(zhí)行命令,站點上的命令過多。
- 211系統(tǒng)狀態(tài),或系統(tǒng)幫助答復(fù)。
- 212目錄狀態(tài)。
- 213文件狀態(tài)。
- 214幫助消息。
- 215NAME系統(tǒng)類型,其中,NAME是AssignedNumbers文檔中所列的正式系統(tǒng)名稱。
- 220服務(wù)就緒,可以執(zhí)行新用戶的請求。
- 221服務(wù)關(guān)閉控制連接。如果適當(dāng),請注銷。
- 225數(shù)據(jù)連接打開,沒有進行中的傳輸。
- 226關(guān)閉數(shù)據(jù)連接。請求的文件操作已成功(例如,傳輸文件或放棄文件)。
- 227進入被動模式(h1,h2,h3,h4,p1,p2)。
- 230用戶已登錄,繼續(xù)進行。
- 250請求的文件操作正確,已完成。
- 257已創(chuàng)建“PATHNAME”。
- 3xx-肯定的中間答復(fù)
該命令已成功,但服務(wù)器需要更多來自客戶端的信息以完成對請求的處理。331用戶名正確,需要密碼。
- 332需要登錄帳戶。
- 350請求的文件操作正在等待進一步的信息。
- 4xx-瞬態(tài)否定的完成答復(fù)
該命令不成功,但錯誤是暫時的。如果客戶端重試命令,可能會執(zhí)行成功。421服務(wù)不可用,正在關(guān)閉控制連接。如果服務(wù)確定它必須關(guān)閉,將向任何命令發(fā)送這一應(yīng)答。
- 425無法打開數(shù)據(jù)連接。
- 426Connectionclosed;transferaborted.
- 450未執(zhí)行請求的文件操作。文件不可用(例如,文件繁忙)。
- 451請求的操作異常終止:正在處理本地錯誤。
- 452未執(zhí)行請求的操作。系統(tǒng)存儲空間不夠。
- 5xx-永久性否定的完成答復(fù)
該命令不成功,錯誤是永久性的。如果客戶端重試命令,將再次出現(xiàn)同樣的錯誤。500語法錯誤,命令無法識別。這可能包括諸如命令行太長之類的錯誤。
- 501在參數(shù)中有語法錯誤。
- 502未執(zhí)行命令。
- 503錯誤的命令序列。
- 504未執(zhí)行該參數(shù)的命令。
- 530未登錄。
- 532存儲文件需要帳戶。
- 550未執(zhí)行請求的操作。文件不可用(例如,未找到文件,沒有訪問權(quán)限)。
- 551請求的操作異常終止:未知的頁面類型。
- 552請求的文件操作異常終止:超出存儲分配(對于當(dāng)前目錄或數(shù)據(jù)集)。
- 553未執(zhí)行請求的操作。不允許的文件名。
- 常見的FTP狀態(tài)代碼及其原因
- 150-FTP使用兩個端口:21用于發(fā)送命令,20用于發(fā)送數(shù)據(jù)。狀態(tài)代碼150表示服務(wù)器準(zhǔn)備在端口20上打開新連接,發(fā)送一些數(shù)據(jù)。
- 226-命令在端口20上打開數(shù)據(jù)連接以執(zhí)行操作,如傳輸文件。該操作成功完成,數(shù)據(jù)連接已關(guān)閉。
- 230-客戶端發(fā)送正確的密碼后,顯示該狀態(tài)代碼。它表示用戶已成功登錄。
- 331-客戶端發(fā)送用戶名后,顯示該狀態(tài)代碼。無論所提供的用戶名是否為系統(tǒng)中的有效帳戶,都將顯示該狀態(tài)代碼。
- 426-命令打開數(shù)據(jù)連接以執(zhí)行操作,但該操作已被取消,數(shù)據(jù)連接已關(guān)閉。
- 530-該狀態(tài)代碼表示用戶無法登錄,因為用戶名和密碼組合無效。如果使用某個用戶帳戶登錄,可能鍵入錯誤的用戶名或密碼,也可能選擇只允許匿名訪問。如果使用匿名帳戶登錄,IIS的配置可能拒絕匿名訪問。
- 550-命令未被執(zhí)行,因為指定的文件不可用。例如,要GET的文件并不存在,或試圖將文件PUT到您沒有寫入權(quán)限的目錄。
當(dāng)前標(biāo)題:創(chuàng)新互聯(lián)JSON教程:jquery中的ajax方法怎樣通過JSONP進行遠程調(diào)用
鏈接地址:http://www.dlmjj.cn/article/dpgissg.html


咨詢
建站咨詢
