ajax提交到servelt獲取參數(shù)有亂碼的解決方法
ajax
技術(shù)或更多。我僅僅闡述一個(gè)現(xiàn)象,一個(gè)解決方法;原因、
原理,同樣不清楚
……
我們先從簡(jiǎn)單的著手,
servlet傳值到JSP頁(yè)面js
腳本中,利用腳本將相關(guān)值顯示在頁(yè)面。解決這個(gè)方向(servlet——javascript)的中文亂碼問(wèn)題很簡(jiǎn)單。只需要在
servlet中,添加一個(gè)
編碼設(shè)置:
response.setContentType("text/html;charset=UTF-8");
而且JSP頁(yè)面編碼方式可以隨意設(shè)定,GBK、GB2312、UTF-8,當(dāng)然
ISO-8859-1是不行的,至少你要在頁(yè)面顯示中文。
從js腳本傳中文到servlet,問(wèn)題因xmlHttp對(duì)象open()方法中,傳值方式(GET、POST)不同,而分為兩種情況:
在介紹這個(gè)問(wèn)題之前,先將兩種傳值方式區(qū)別展示一下:
假設(shè)傳遞值“軟件工程”,變量名為“selcol”。
1、GET方法:
function selectCol(){
createXMLHttpRequest();
var selcol = "
軟件工程
";
var url = "/emp/FindSpecial?selcol=" + selcol;
xmlHttp.onreadystatechange = handleStateChange;
xmlHttp.open("GET",url,true);
xmlHttp.send(null);
}
2、POST方法:
function selectCol(){
createXMLHttpRequest();
var selcol = "selcol=軟件工程";
var url = "/emp/FindSpecial";
xmlHttp.onreadystatechange = handleStateChange;
xmlHttp.open("POST",url,true);
xmlHttpxmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlHttp.send(selcol);
}
如果使用GET方式傳遞,那么我們?cè)趕ervlet拿值的時(shí)候,以如下方式轉(zhuǎn)編碼:
String selcol = new String(request.getParameter("selcol").getBytes("ISO-8859-1"), "GBK");
轉(zhuǎn)GBK、GB2312都行,轉(zhuǎn)UTF-8不行!
這個(gè)時(shí)候也許你會(huì)很奇怪的發(fā)現(xiàn),這兩個(gè)語(yǔ)句竟然同時(shí)出現(xiàn):
response.setContentType("text/html;charset=UTF-8");
String selcol = new String(request.getParameter("selcol").getBytes("ISO-8859-1"), "GBK");
個(gè)人是這樣理解的:第一句僅保證,從此servlet傳遞出去的數(shù)據(jù)編碼方式為UTF-8;
而后者則是將傳遞進(jìn)來(lái)的數(shù)據(jù)轉(zhuǎn)化成GBK編碼的數(shù)據(jù)。方便與辨別和處理。
如果使用POST方式傳遞,那么我們?cè)趕ervlet拿值的時(shí)候,同上,只是將編碼轉(zhuǎn)為UTF-8,
而這個(gè)時(shí)候,GBK和GB2312不行!
String selcol = new String(request.getParameter("selcol").getBytes ("ISO-8859-1"), "UTF-8");
- java操作oracle數(shù)據(jù)庫(kù)示例
- java調(diào)用oracle分頁(yè)存儲(chǔ)過(guò)程示例
- java讀寫(xiě)oracle的blob字段示例
- JAVA簡(jiǎn)單鏈接Oracle數(shù)據(jù)庫(kù) 注冊(cè)和登陸功能的實(shí)現(xiàn)代碼
- Java使用JDBC連接Oracle_MSSQL實(shí)例代碼
- java使用jdbc鏈接Oracle示例類分享
- JSP連接MySql/MS SQL Server/Oracle數(shù)據(jù)庫(kù)連接方法[整理]
- 在JSP中訪問(wèn)Oracle數(shù)據(jù)庫(kù)
- Java實(shí)現(xiàn)JSP在Servelt中連接Oracle數(shù)據(jù)庫(kù)的方法
相關(guān)文章
用ajax實(shí)現(xiàn)在單擊事件下加載一個(gè)DIV層的腳本
用ajax實(shí)現(xiàn)在單擊事件下加載一個(gè)DIV層的腳本...2007-11-11基于Ajax+div的“左邊菜單、右邊內(nèi)容”頁(yè)面效果實(shí)現(xiàn)
這篇文章主要介紹了基于Ajax+div的“左邊菜單、右邊內(nèi)容”頁(yè)面效果實(shí)現(xiàn) 的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07jquery ajax提交表單從action傳值到j(luò)sp實(shí)現(xiàn)小結(jié)
pw.print(random);這里的random就是action要向jsp傳的值,在jsp中,success: function(text)這里的text就是接收從action傳過(guò)來(lái)的值,感興趣的朋友可以參考下哈2013-04-04AJAX請(qǐng)求隊(duì)列實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了AJAX請(qǐng)求隊(duì)列的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11PHP+AJAX無(wú)刷新實(shí)現(xiàn)返回天氣預(yù)報(bào)數(shù)據(jù)
天氣數(shù)據(jù)是通過(guò)采集中國(guó)氣象網(wǎng)站的。本來(lái)中國(guó)天氣網(wǎng)站也給出了數(shù)據(jù)的API接口,接下來(lái)為大家介紹下用php來(lái)寫(xiě)一個(gè)天氣預(yù)報(bào)的模塊,感興趣的朋友可以參考下2013-07-07ajax JSONP請(qǐng)求處理回調(diào)函數(shù)jsonpCallback區(qū)分大小寫(xiě)
使用ajax進(jìn)行 JSONP跨域請(qǐng)求,因?yàn)楸徽?qǐng)求的對(duì)方的回調(diào)函數(shù)名稱是無(wú)法修改,想到設(shè)置AJAX 的JSONP參數(shù)。但是發(fā)現(xiàn)根本不起作用。最后偶然發(fā)現(xiàn) jsonpcallback是區(qū)分大小寫(xiě)的2013-09-09滑輪滾動(dòng)到頁(yè)面底部ajax加載數(shù)據(jù)配合jsonp實(shí)現(xiàn)探討
滾動(dòng)下拉到頁(yè)面底部加載數(shù)據(jù)是很多瀑布流網(wǎng)站的做法,那來(lái)看看配合jsonp是如何實(shí)現(xiàn)的吧,小菜總結(jié)記錄之用特在此與大家一起分享,感興趣的朋友可以參考下哈2013-05-05