由於AJax在跨域的訪問上有問題,目前最好的方法是做代理.寫了個代理程序和心得.
為了做ajax的代理,研究了下服務器端的xmlhttp並和客戶端的AJax中的XMLhttp做了個比較,後台代碼是ASP的.
服務器端的XMLhttp也就是ASP小偷程序,我把代碼改成了Javascript.
1.在服務器端的XMLhttp.Open("GET",url,false)異步必須是關閉的,而客戶端的異步是打開的,這個很好理解.
2.在服務器端的xmlhttp.Responsebody 這裡用的是Responsebody而不是ResponseText或ResponseXML,一開始我是用ResponseText,但在函數bytesToBSTR轉換編碼的時候提示錯誤,經過比較發現其他的ASP小偷程序裡的代碼都是Responsebody,分析後,發現body返回來的是二進制數據而不是像ResponseText或ResponseXML那樣返回字符或dom對象.
AJax的ASP代理函數介紹:
send_request(url) ,url為地址
服務器端代碼如下帶自動判斷所有字符編碼,已測試 日語 韓語 繁體:
<%@LANGUAGE="JavaSCRIPT" CODEPAGE="65001"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD Html 4.01 Transitional//EN"
"http://www.w3.org/TR/Html4/loose.dtd">
<Html>
<head>
<meta http-equiv="Content-Type" content="text/Html; charset=utf-8">
<title>XMLHTTP</title>
</head>
<%
Server.ScriptTimeout=9999999;
function send_request(url) {
var codedtext;
http_request = Server.CreateObject("Microsoft.XMLHTTP");
http_request.Open("GET",url,false);
http_request.Send(null);
if (http_request.ReadyState == 4){
//自動判斷編碼開始
var charresult = http_request.ResponseText.match(/CharSet=(\S+)\">/i);
if (charresult != null){
var Cset = charresult[1];
}else{Cset = "gb2312"}//對獲取不到的網站采用gb2312編碼,可自行更改
//自動判斷編碼結束
codedtext = bytesToBSTR(http_request.Responsebody,Cset);
}else{
codedtext = "Erro";
}
return(codedtext);
}
function bytesToBSTR(body,Cset){
var obJStream;
obJStream = Server.CreateObject("Adodb.Stream");
obJStream.Type = 1;
obJStream.Mode = 3;
obJStream.Open();
obJStream.Write(body);
obJStream.Position = 0;
obJStream.Type = 2;
obJStream.Charset = Cset;
bytesToBSTR = obJStream.Readtext;
obJStream.Close;
return(bytesToBSTR);
}
%>
<body>
<% Response.Write(send_request("http://www.daum.Net")) %>
</body>
</Html>