jquery中的ajax方法怎樣通過(guò)JSONP進(jìn)行遠(yuǎn)程調(diào)用

2022-05-17 14:21 更新

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

$.ajax的參數(shù)

首先介紹下$.ajax的參數(shù): 

  • type:請(qǐng)求方式 GET/POST 
  • url:請(qǐng)求地址 
  • async:布爾類(lèi)型,默認(rèn)為true 表示請(qǐng)求是否為異步,如果為false表示為同步。 
  • dataType:返回的數(shù)據(jù)類(lèi)型 
  • jsonp:傳遞給請(qǐng)求處理程序或頁(yè)面的,用以獲得jsonp回調(diào)函數(shù)名的參數(shù)名(一般默認(rèn)為:callback) 
  • jsonpCallback:自定義的jsonp回調(diào)函數(shù)名稱(chēng),默認(rèn)為jQuery自動(dòng)生成的隨機(jī)函數(shù)名,也可以寫(xiě)"?",jQuery會(huì)自動(dòng)為你處理數(shù)據(jù) 
  • success:調(diào)用成功執(zhí)行的函數(shù) 
  • error:異常處理函數(shù) 

1、示例1 

服務(wù)器端我們采用MVC的ACTION來(lái)返回?cái)?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); 
  } 
} 

客戶(hù)端使用jsonp來(lái)傳輸數(shù)據(jù) 

代碼如下:
@{ 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();"/> 

點(diǎn)擊提交按鈕后,發(fā)現(xiàn)服務(wù)器端的Request.QueryString["callback"]返回一個(gè)隨機(jī)函數(shù)名。這樣就被設(shè)置成JSONP格式來(lái)傳遞數(shù)據(jù)了 

2.自定義函數(shù)名 

可以在傳遞過(guò)程中自定義函數(shù)名,只要使用jsonpCallback參數(shù)就可以了。 

  • jsonp:表示傳遞的參數(shù),默認(rèn)為callback,我們也可以自定義,服務(wù)器段通過(guò)此參數(shù),獲取自定義的函數(shù)名稱(chēng),服務(wù)器這樣獲取 Request.QueryString["callback"] 
  • jsonpCallback:表示傳遞的參數(shù)值,也就是回調(diào)的函數(shù)名稱(chēng),這是自定義的名稱(chēng)。 

代碼如下:
<script type="text/javascript"> 
functionSendData() { 
$.ajax({ 
type: "get", 
async: false, 
url: "/home/ReturnJson", 
dataType: "jsonp", 
jsonp: "callback",//傳遞給請(qǐng)求處理程序或頁(yè)面的,用以獲得jsonp回調(diào)函數(shù)名的參數(shù)名(一般默認(rèn)為:callback) 
jsonpCallback: "receive",//自定義的jsonp回調(diào)函數(shù)名稱(chēng),默認(rèn)為jQuery自動(dòng)生成的隨機(jī)函數(shù)名,也可以寫(xiě)"?",jQuery會(huì)自動(dòng)為你處理數(shù)據(jù) 
success: function(data) { 
alert(data.name); 
}, 
error: function() { 
alert('fail'); 
} 
}); 
} 

functionreceive(data) { 
alert(data.age); 
} 
</script> 
jQuery AJAX實(shí)現(xiàn)調(diào)用頁(yè)面后臺(tái)方法

Add1: 使用AJAX訪問(wèn)aspx頁(yè)面和asmx使用方法是一樣的,區(qū)別在于aspx頁(yè)面中的方法必須為靜態(tài)方法,而asmx不需要.

1.新建demo.aspx頁(yè)面。
2.首先在該頁(yè)面的后臺(tái)文件demos.aspx.cs中添加引用。

using System.Web.Services;

3.無(wú)參數(shù)的方法調(diào)用.

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

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

JS代碼:

$(function() {     
    $("#btnOK").click(function() {     
        $.ajax({     
            //要用post方式      
            type: "Post",     
            //方法所在頁(yè)面和方法名      
            url: "Demo.aspx/SayHello",    
            //沒(méi)有參數(shù)也一定要傳一個(gè)空參數(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;     
    });     
});    

頁(yè)面代碼:

<form id="form1" runat="server">
    <div>
        <%--<asp:Button ID="btnOK" runat="server" Text="驗(yàn)證用戶(hù)" />--%>
         <%--因?yàn)槭钱惒剑灾荒苁褂胔tml,上面的服務(wù)器控件是錯(cuò)誤的 可以測(cè)試下--%>
        <input    id="btnOK" type="button" value="button" /> 
    </div>
</form>

運(yùn)行效果如下:

ajax

3.有參數(shù)方法調(diào)用后臺(tái)代碼:

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

JS代碼:

$(function() {     
    $("#btnOK").click(function() {     
        $.ajax({     
            type: "Post",     
            url: "demo.aspx/GetStr",     
            //方法傳參的寫(xiě)法一定要對(duì),str為形參的名字,str2為第二個(gè)形參的名字      
            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;     
    });     
});    

運(yùn)行效果如下:

w3c

4.返回?cái)?shù)組方法
后臺(tái)代碼:

[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("");     
    
                //遞歸獲取數(shù)據(jù)      
                $(data.d).each(function() {     
                    //插入結(jié)果到li里面      
                    $("#list").append("<li>" + this + "</li>");     
                });     
    
                alert(data.d);     
            },     
            error: function(err) {     
                alert(err);     
            }     
        });     
    
        //禁用按鈕的提交      
        return false;     
    });     
}); 

頁(yè)面代碼:

<form id="form1" runat="server">
<div>
    <asp:Button ID="btnOK" runat="server" Text="驗(yàn)證用戶(hù)" />
</div>
<ul id="list">
</ul>
</form>

運(yùn)行結(jié)果圖:

jquery

下面是Jquery中AJAX參數(shù)詳細(xì)列表:

參數(shù)名 類(lèi)型 描述
url String (默認(rèn): 當(dāng)前頁(yè)地址) 發(fā)送請(qǐng)求的地址。
type String (默認(rèn): "GET") 請(qǐng)求方式 ("POST" 或 "GET"), 默認(rèn)為 "GET"。注意:其它 HTTP 請(qǐng)求方法,如 PUT 和 DELETE 也可以使用,但僅部分瀏覽器支持。
timeout Number 設(shè)置請(qǐng)求超時(shí)時(shí)間(毫秒)。此設(shè)置將覆蓋全局設(shè)置。
async Boolean (默認(rèn): true) 默認(rèn)設(shè)置下,所有請(qǐng)求均為異步請(qǐng)求。如果需要發(fā)送同步請(qǐng)求,請(qǐng)將此選項(xiàng)設(shè)置為 false。注意,同步請(qǐng)求將鎖住瀏覽器,用戶(hù)其它操作必須等待請(qǐng)求完成才可以執(zhí)行。
beforeSend Function 發(fā)送請(qǐng)求前可修改 XMLHttpRequest 對(duì)象的函數(shù),如添加自定義 HTTP 頭。XMLHttpRequest 對(duì)象是唯一的參數(shù)。
function (XMLHttpRequest) {
  this; // the options for this ajax request
}
cache Boolean (默認(rèn): true) jQuery 1.2 新功能,設(shè)置為 false 將不會(huì)從瀏覽器緩存中加載請(qǐng)求信息。
complete Function 請(qǐng)求完成后回調(diào)函數(shù) (請(qǐng)求成功或失敗時(shí)均調(diào)用)。參數(shù): XMLHttpRequest 對(duì)象,成功信息字符串。
function (XMLHttpRequest, textStatus) {
  this; // the options for this ajax request
}
contentType String (默認(rèn): "application/x-www-form-urlencoded") 發(fā)送信息至服務(wù)器時(shí)內(nèi)容編碼類(lèi)型。默認(rèn)值適合大多數(shù)應(yīng)用場(chǎng)合。
data Object,
String
發(fā) 送到服務(wù)器的數(shù)據(jù)。將自動(dòng)轉(zhuǎn)換為請(qǐng)求字符串格式。GET 請(qǐng)求中將附加在 URL 后。查看 processData 選項(xiàng)說(shuō)明以禁止此自動(dòng)轉(zhuǎn)換。必須為 Key/Value 格式。如果為數(shù)組,jQuery 將自動(dòng)為不同值對(duì)應(yīng)同一個(gè)名稱(chēng)。如 {foo:["bar1", "bar2"]} 轉(zhuǎn)換為 '&foo=bar1&foo=bar2'。
dataType String

預(yù)期服務(wù)器返回的數(shù)據(jù)類(lèi)型。如果不指定,jQuery 將自動(dòng)根據(jù) HTTP 包 MIME 信息返回 responseXML 或 responseText,并作為回調(diào)函數(shù)參數(shù)傳遞,可用值:

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

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

"script": 返回純文本 JavaScript 代碼。不會(huì)自動(dòng)緩存結(jié)果。

"json": 返回 JSON 數(shù)據(jù) 。

"jsonp": JSONP 格式。使用 JSONP 形式調(diào)用函數(shù)時(shí),如 "myurl?callback=?" jQuery 將自動(dòng)替換 ? 為正確的函數(shù)名,以執(zhí)行回調(diào)函數(shù)。

error Function (默認(rèn): 自動(dòng)判斷 (xml 或 html)) 請(qǐng)求失敗時(shí)將調(diào)用此方法。這個(gè)方法有三個(gè)參數(shù):XMLHttpRequest 對(duì)象,錯(cuò)誤信息,(可能)捕獲的錯(cuò)誤對(duì)象。
function (XMLHttpRequest, textStatus, errorThrown) {
  // 通常情況下textStatus和errorThown只有其中一個(gè)有值 
  this; // the options for this ajax request
}
global Boolean (默認(rèn): true) 是否觸發(fā)全局 AJAX 事件。設(shè)置為 false 將不會(huì)觸發(fā)全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用于控制不同的Ajax事件
ifModified Boolean (默認(rèn): false) 僅在服務(wù)器數(shù)據(jù)改變時(shí)獲取新數(shù)據(jù)。使用 HTTP 包 Last-Modified 頭信息判斷。
processData Boolean (默認(rèn): true) 默認(rèn)情況下,發(fā)送的數(shù)據(jù)將被轉(zhuǎn)換為對(duì)象(技術(shù)上講并非字符串) 以配合默認(rèn)內(nèi)容類(lèi)型 "application/x-www-form-urlencoded"。如果要發(fā)送 DOM 樹(shù)信息或其它不希望轉(zhuǎn)換的信息,請(qǐng)?jiān)O(shè)置為 false。
success Function 請(qǐng)求成功后回調(diào)函數(shù)。這個(gè)方法有兩個(gè)參數(shù):服務(wù)器返回?cái)?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請(qǐng)求時(shí)傳遞的options參數(shù)
                    }
                });
            });
        });

一、error:function (XMLHttpRequest, textStatus, errorThrown) { } 
(默 認(rèn): 自動(dòng)判斷 (xml 或 html)) 請(qǐng)求失敗時(shí)調(diào)用時(shí)間。參數(shù)有以下三個(gè):XMLHttpRequest 對(duì)象、錯(cuò)誤信息、(可選)捕獲的錯(cuò)誤對(duì)象。如果發(fā)生了錯(cuò)誤,錯(cuò)誤信息(第二個(gè)參數(shù))除了得到null之外,還可能是"timeout", "error", "notmodified" 和 "parsererror"。

textStatus:

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


二、error事件返回的第一個(gè)參數(shù)XMLHttpRequest有一些有用的信息:

XMLHttpRequest.readyState:

狀態(tài)碼 

0 - (未初始化)還沒(méi)有調(diào)用send()方法 

1 - (載入)已調(diào)用send()方法,正在發(fā)送請(qǐng)求 

2 - (載入完成)send()方法執(zhí)行完成,已經(jīng)接收到全部響應(yīng)內(nèi)容 

3 - (交互)正在解析響應(yīng)內(nèi)容 

4 - (完成)響應(yīng)內(nèi)容解析完成,可以在客戶(hù)端調(diào)用了


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


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


五、XMLHttpRequest.status:

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

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)