好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > AJAX在GB2312的中文編碼傳輸 AJAX特殊字符編碼正確方法

AJAX在GB2312的中文編碼傳輸 AJAX特殊字符編碼正確方法

熱門標簽:接聽電話機器人哪有 蓄意標記地圖標注 信貸電銷機器人有用嗎 廣西ai語音電銷機器人哪家好 察縣地圖標注 電銷機器人適用范圍 莆田防封電銷卡價格 如何用地圖標注各分公司 辦理一個400電話多少錢
很多可能在轉摘過程中失真或未經驗證就被轉摘,真正使用時卻不行,也由此決定自己全方位試驗一下,努力還是沒有白費,雖然最終得出的結果是很簡單的,但其過程對于一個新學AJAX的人來說,真是挺累。
歡迎您在使用過程中對新的心得一起跟帖交流,一個思想+一個思想,至少可以產生兩個思想。

一、在GET發送時:

方法1:在ASP服務器端用Response.charset="GB2312"界定輸出編碼給調用客戶端
此時客戶端不需要做什么轉換即可。如下兩個文件:
1、客戶端JS
復制代碼 代碼如下:

var xmlHttp;
function createXML(){
if(window.ActiveXObject){
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}else if(window.XMLHttpRequest){
xmlHttp=new XMLHttpRequest();
}
}
function startXml(){
createXML();
xmlHttp.onreadystatechange = handleStateChange;
var url="ajaxtext.asp?tm=1cc"+Math.random();
//var sendContents = 'theinput='+escape(theinput.value);
var regcode="2abc";
xmlHttp.open("get",url,true);
//regcode="regcode="+regcode;
//xmlHttp.setrequestheader("content-length",regcode.length); //可加可不加
//xmlHttp.setRequestHeader("Cache-Control","no-cache");
//xmlHttp.setRequestHeader('Content-type','application/x-www-form-urlencoded'); //可不加
//xmlHttp.send(null);
//xmlHttp.send("regcode="+escape(regcode));
xmlHttp.send(null);
}
function handleStateChange(){
if (xmlHttp.readyState == 4 xmlHttp.status==200){
//var divid=document.getElementById("results");
retext=xmlHttp.responseText;
alert(retext);
//if(divid.hasChildNodes()){
// divid.removeChild(divid.childNodes[0]);
//}
//var result=document.createTextNode(xmlHttp.responseText);
//divid.appendChild(result);
//document.getElementById("results").innerHTML=xmlHttp.responseText;
}
}

服務器端:
復制代碼 代碼如下:

%Response.CodePage=936%>
%Response.charset="GB2312"
dim reg
reg=Request("regcode")
Response.write "王先生·和他的朋友" '可以正確輸出。
%>

方法2:在客戶端用函數轉換(來自網上)。
復制代碼 代碼如下:

function gb2utf8(data){
var glbEncode = [];
gb2utf8_data = data;
execScript("gb2utf8_data = MidB(gb2utf8_data, 1)", "VBScript");
var t=escape(gb2utf8_data).replace(/%u/g,"").replace(/(.{2})(.{2})/g,"%$2%$1").replace(/%([A-Z].)%(.{2})/g,"@$1$2");
t=t.split("@");
var i=0,j=t.length,k;
while(++ij) {
k=t[i].substring(0,4);
if(!glbEncode[k]) {
gb2utf8_char = eval("0x"+k);
execScript("gb2utf8_char = Chr(gb2utf8_char)", "VBScript");
glbEncode[k]=escape(gb2utf8_char).substring(1,6);
}
t[i]=glbEncode[k]+t[i].substring(4);
}
gb2utf8_data = gb2utf8_char = null;
return unescape(t.join("%"));
}

此時如果服務器端不指明編碼,那么AJAX默認為UTF-8,就不能在客戶端顯示,用這個函數就可以。
復制代碼 代碼如下:

retext=xmlHttp.responseText;
retext=gb2utf8(retext);
alert(retext);

3、在火狐瀏覽器下:具體請參考:下一篇文章

火狐比較簡單,他可以支持xmlHttp.responseText;//FireFox,但為了代碼簡化,建議用上面的直接做好編碼。
但如果為了通用,就按POST下面介紹的方法來做吧。

二、在POST發送時:

對于常規的中文,上述的GET方法在POST也是可以的,但網上有一篇文章提到了部分符號不能顯示的,比如:下一篇文章中的“test·test+test·”,(中間是間隔號)測試過了,的確在服務器端界定編碼后輸出給客戶端也不能顯示。

如果按照文中所說的,
發送端用xmlHttp.send("regcode="+escape(regcode));

然后在服務器端將接收的數據套上兩個編碼encodeURIComponent(escape(xxxxxxx)),則顯示的結果是:test%25u7A5Eest%2520test,同樣不行。另外這個思路應是不對的,不知道這篇文章在網上被轉抄時是否本身就有錯,按理在客戶端用escape編碼傳送后,在服務器端就應該反編碼?;蛘逺EQUEST本身就有解碼的作用。不需要再二次、三次編碼。況且查了一下,escape和encodeURIComponent也無法對特殊字符編碼。

我在服務器端做了如下輸出:
復制代碼 代碼如下:

test2="test·test+test·回饋:"
Response.write test2"前面是服務器直接輸出的而非接收的特殊符號“·”間隔號。后面是接收的數據(內容與原AJAX發送的一樣,用于對比):"

也就是說直接在服務器端生成一個同樣的含特殊字符,這個服務器端文件已經用%Response.charset="GB2312"%>定義好編碼為GB2312。但輸出的結果是,在服務器端生成的test2="test·test+test·回饋:"可以正常輸出,而接收的AJAX值就不行了。
即使在客戶端用JS三個編碼參數escape()\encodeURI() \encodeURIComponent() 全部試過去,然后在服務器商反編碼再輸出,也是不行。這說明字串中的特殊符號在服務器端接收時就已經變形了。

現在問題界定在編碼傳遞上了,為了說明這個問題,我又做了一個小試驗:就是把這個字串賦值給ASP的一個變量再用ASP變量來賦值給JS,如下:
復制代碼 代碼如下:

%
para="test·test+test·/"
para=Server.urlencode(para)
%>

然后轉手給JS變量,如下:
復制代碼 代碼如下:

xmlHttp.open("POST",url,true);
var regcode="%=para%>";
xmlHttp.setRequestHeader('Content-type','application/x-www-form-urlencoded;charset=gb2312');
xmlHttp.send("regcode="+regcode);

結果正常了,這充分說明ASP的server.urlencode能完整對特殊字符編碼。而JS還是有欠缺。

那現在怎么辦?

在實在沒辦法的情況下,我想到了即然encodeURIComponent()可以比encode()對更多特殊字符編碼,那么不妨像多重MD5加密一樣,增加強化劑,于是我套用了兩個encodeURIComponent(),現在代碼是:
復制代碼 代碼如下:

var regcode="test·test+test·/";
xmlHttp.setRequestHeader('Content-type','application/x-www-form-urlencoded;charset=gb2312');
xmlHttp.send("regcode="+encodeURIComponent(encodeURIComponent(regcode)));

上面是客戶端的,再把服務器端改成:
復制代碼 代碼如下:

script language="javascript" runat="server">
function decodestr(str){
return decodeURIComponent(decodeURIComponent(str));
}
/script>
%
dim reg
reg=Request("regcode")
test2="test·test+test·回饋:"
Response.write test2"前面是服務直接輸入的而非接收的特殊符號“·”間隔號。后面是接收的數據(內容與原AJAX發送的一樣,用于對比):"
Response.write decodestr(reg)
%>

終于完美看到了AJAX輸出的特殊字符。間隔號和+號都出來了,
“test·test+test·/”
為了進一步驗證,我把下面encodeURIComponent也無法編碼的個別特殊字符全加進來了,如下:
復制代碼 代碼如下:

var regcode="漢字開頭:! @ # $ * ( ··) = : / ; ? + 結尾,中間全是特殊字符。";

結果也正常了,太棒!
不過一般AJAX傳給服務器的數據是要應用的,否則沒有意義,為了再進一步驗證數據是否一樣,我把服務器端做了小修改,如下:
復制代碼 代碼如下:

%
dim reg
reg=Request("regcode")
test2="漢字開頭:! @ # $ * ( ··) = : / ; ? + 結尾,中間全是特殊字符。"
IF test2>decodestr(reg) Then
Response.write "不同"
Else
Response.write "相同"
End IF
%>

很興奮??蛻舳溯敵觥跋嗤?,這下可以放心全面應用了。

總結:

1、AJAX客戶端雙重套用encodeURIComponent()對POST的數據編碼。
2、服務器端對應地用decodeURIComponent()雙重解碼即可:
script language="javascript" runat="server">
function decodestr(str){
return decodeURIComponent(decodeURIComponent(str));
}
/script>
3、在接收responseText時,不需要再反編碼了。直接:retext=xmlHttp.responseText;
4、服務器端的這行仍然不可缺:%Response.charset="GB2312"%>,一般在ASP文件中,都有%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>這行,但這行可以去掉,唯獨不能去掉%Response.charset="GB2312"%>,否則出錯。

現在開始,把encodeURIComponent()/decodeURIComponent()背熟就可以。
附:以下幾個編碼方法摘自JS手冊,供參考:

escape() 方法:
采用ISO Latin字符集對指定的字符串進行編碼。所有的空格符、標點符號、特殊字符以及其他非ASCII字符都將被轉化成%xx格式的字符編碼(xx等于該字符在字符集表里面的編碼的16進制數字)。比如,空格符對應的編碼是%20。unescape方法與此相反。不會被此方法編碼的字符: @ * / +

注釋:可以使用 unescape() 對 escape() 編碼的字符串進行解碼。但ECMAScript v3 反對使用這種方法,應用使用 decodeURI() 和 decodeURIComponent() 替代它。

encodeURI() 方法: ------ 注意后面一個是大小的i——“I”不是L,下面的decodeURI也不是L。
把URI字符串采用UTF-8編碼格式轉化成escape格式的字符串。不會被此方法編碼的字符:! @ # $ * ( ) = : / ; ? + '

encodeURIComponent() 方法:
把URI字符串采用UTF-8編碼格式轉化成escape格式的字符串。與encodeURI()相比,這個方法將對更多的字符進行編碼,比如 / 等字符。所以如果字符串里面包含了URI的幾個部分的話,不能用這個方法來進行編碼,否則 / 字符被編碼之后URL將顯示錯誤。不會被此方法編碼的字符:! * ( )


引用內容
因此,對于中文字符串來說,如果不希望把字符串編碼格式轉化成UTF-8格式的(比如原頁面和目標頁面的charset是一致的時候),只需要使用escape。如果你的頁面是GB2312或者其他的編碼,而接受參數的頁面是UTF-8編碼的,就要采用encodeURI或者encodeURIComponent。
另外,encodeURI/encodeURIComponent是在javascript1.5之后引進的,escape則在javascript1.0版本就有。

decodeURI() 函數
decodeURI() 函數可對 encodeURI() 函數編碼過的 URI 進行解碼。
script type="text/javascript">

var test1=http://www.w3school.com.cn/My first/
document.write(encodeURI(test1)+ "br />")
document.write(decodeURI(test1))
/script>

decodeURIComponent() 函數:可對 encodeURIComponent() 函數編碼的 URI 進行解碼。
unescape():對escape解碼。
作者:非物理生命博客traindiy
您可能感興趣的文章:
  • jquery與ajax獲取特殊字符實例詳解
  • jQuery 實現ajax傳入參數含有特殊字符的方法總結
  • ajax傳送參數含有特殊字符的快速解決方法
  • jquery ajax對特殊字符進行轉義防止js注入使用示例
  • Ajax傳遞特殊字符的數據如何解決

標簽:張掖 延邊 阿拉善盟 益陽 鷹潭 平涼 儋州 銅陵

巨人網絡通訊聲明:本文標題《AJAX在GB2312的中文編碼傳輸 AJAX特殊字符編碼正確方法》,本文關鍵詞  AJAX,在,GB2312,的,中文,編碼,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《AJAX在GB2312的中文編碼傳輸 AJAX特殊字符編碼正確方法》相關的同類信息!
  • 本頁收集關于AJAX在GB2312的中文編碼傳輸 AJAX特殊字符編碼正確方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 特一级电影| 哥哥的老婆| 国产精品偷伦视频免费观看了软件| 蜜臀色欲AV在线播放国产日韩| 中文字幕第13亚洲另类| 久草视频在线看| 琪琪成人影院| 被两老头把我添高潮了| 中文字幕日韩人妻在线| 免费伊人网| 日本午夜色大片在线观看| 中文字幕一区二区日韩精品蜜臀| 亚洲夜夜夜| 啊好爽用力插| 在线播放a| 亚洲永久无码69堂.m3u8| 97久久超碰国产精品电影| 青青青青青国产免费手机看视频| 久久福利影院| 国产凌凌漆免费完整高清国语| 变态另类视频一区二区三区| 91自啪区| 边吃奶边扎下很爽视频| 免费男人添女人下身视频高清| 婷婷丁香综合色AV天堂| 蜜桃AV精品久久| 在线理论视频| 国产不卡| 欧美xx性| 秘?韩H漫画免费羞羞漫画观看| 国产69精品久久久久APP下载| 蜜桃tv在线| 乳糖不耐受po豆乳芝士| jk漫画?黄漫免费网站| 国产情侣一区二区三区| 一级视频在线| 榴莲视频免费app| 日本欧美一区二区| 法国淫欲的代价2k8| 午夜福利伦伦电影理论片在线观看| 第一版主新婚第二部59|