<script language="javascript" type="text/javascript">
//建立相容瀏覽器的XMLHttpRequest對象
function createXMLHttp()
{
var XmlHttp;
if (window.ActiveXObject)
{
var arr=["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.5.0",
"MSXML2.XMLHttp.4.0","MSXML2.XMLHttp.3.0","MSXML2.XMLHttp","Microsoft.XMLHttp"];
for(var i=0;i<arr.length;i++)
{
try
{
XmlHttp=new ActiveXObject(arr[i]);
return XmlHttp;
}
catch(error)
{
}
}
}
else
{
try
{
XmlHttp=new XMLHttpRequest();
return XmlHttp;
}
catch(otherError)
{
}
}
}
function xmlpost()
{
var xmlHttp=createXMLHttp();
var Fileurl='CheckUnameHandler.ashx?uname='+username.value;//接受值的url
xmlHttp.open('GET',Fileurl,true);
xmlHttp.onreadystatechange = function(){
if(xmlHttp.readystate == 4 && xmlHttp.status == 200)
{
var result=xmlHttp.responseText;
alert(result);
if(result=='0')
{
spcheckname.innerHTML = '使用者名稱可用!';
document.getElementById('<%=this.btnsub.ClientID %>').disabled = '';
}
else if(result=='1')
{
spcheckname.innerHTML = '使用者名稱被佔用!';
document.getElementById('<%=this.btnsub.ClientID %>').disabled = 'disabled';
}
}
else
{
spcheckname.innerHTML = '由於操作過快! 導致資料驗證失敗!';
}
}
xmlHttp.send('');
}
</script>
備忘:
xmlHttp.status的值(HTTP狀態表)
0**:未被始化
1**:請求收到,繼續處理
2**:操作成功收到,分析、接受
3**:完成此請求必須進一步處理
4**:請求包含一個錯誤文法或不能完成
5**:伺服器執行一個完全有效請求失敗
100——客戶必須繼續發出請求
101——客戶要求伺服器根據請求轉換HTTP協議版本
200——交易成功
201——提示知道新檔案的URL
202——接受和處理、但處理未完成
203——返回資訊不確定或不完整
204——請求收到,但返回資訊為空白
205——伺服器完成了請求,使用者代理程式必須複位當前已經瀏覽過的檔案
206——伺服器已經完成了部分使用者的GET請求
300——請求的資源可在多處得到
301——刪除請求資料
302——在其他地址發現了請求資料
303——建議客戶訪問其他URL或訪問方式
304——用戶端已經執行了GET,但檔案未變化
305——請求的資源必須從伺服器指定的地址得到
306——前一版本HTTP中使用的代碼,現行版本中不再使用
307——申明請求的資源臨時性刪除
400——錯誤請求,如語法錯誤
401——請求授權失敗
402——保留有效ChargeTo頭響應
403——請求不允許
404——沒有發現檔案、查詢或URl
405——使用者在Request-Line欄位定義的方法不允許
406——根據使用者發送的Accept拖,請求資源不可訪問
407——類似401,使用者必須首先在Proxy 伺服器上得到授權
408——用戶端沒有在使用者指定的餓時間內完成請求
409——對當前資源狀態,請求不能完成
410——伺服器上不再有此資源且無進一步的參考地址
411——伺服器拒絕使用者定義的Content-Length屬性請求
412——一個或多個要求標頭欄位在當前請求中錯誤
413——請求的資源大於伺服器允許的大小
414——請求的資源URL長於伺服器允許的長度
415——請求資源不支援要求項目格式
416——請求中包含Range要求標頭欄位,在當前請求資源範圍內沒有range指示值,請求也不包含If-Range要求標頭欄位
417——伺服器不滿足請求Expect頭欄位指定的期望值,如果是Proxy 伺服器,可能是下一級伺服器不能滿足請求
500——伺服器產生內部錯誤
501——伺服器不支援要求的函數
502——伺服器暫時不可用,有時是為了防止發生系統過載
503——伺服器過載或暫停維修
504——關口過載,伺服器使用另一個關口或服務來響應使用者,等待時間設定值較長
505——伺服器不支援或拒絕支要求標頭中指定的HTTP版本
1xx:資訊響應類,表示接收到請求並且繼續處理
2xx:處理成功響應類,表示動作被成功接收、理解和接受
3xx:重新導向響應類,為了完成指定的動作,必須接受進一步處理
4xx:用戶端錯誤,客戶請求包含語法錯誤或者是不能正確執行
5xx:服務端錯誤,伺服器不能正確執行一個正確的請求