DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX基礎知識 >> ajax代理程序,自動判斷字符編碼
ajax代理程序,自動判斷字符編碼
編輯:AJAX基礎知識     
由於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>

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved