Ajax request response 亂碼解決方法
AjaxRequestObj.createEqStatusParameter=function() {
if (eqStatusArray.length < 1) {
return;
}
var paramNameArray = new Array();
var paramValueArray = new Array();
//取狀態(tài)數(shù)組
for (var index = 0, step = eqStatusArray.length; index < step; index++) {
var tempEqStatusObj = eqStatusArray[index];
paramNameArray.push(tempEqStatusObj.eqCode + "`" + tempEqStatusObj.opDateTime);
paramValueArray.push(tempEqStatusObj.status);
}
//分解、生成請(qǐng)求串。
var paramStr = "";
paramStr = paramStr.concat("eqStatusNames=").concat(encodeURIComponent(paramNameArray.join(","))).concat("&");
paramStr = paramStr.concat("eqStatusValues=").concat(encodeURIComponent(paramValueArray.join("`")));
return paramStr;
};
xmlHttpObj.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
xmlHttpObj.send(param);
客戶(hù)端將參數(shù)以UTF-8方式傳遞給應(yīng)用端,在使用此參數(shù)時(shí)直接從request中取就可以。
[Ajax接收響應(yīng)信息]
直接使用forward跳轉(zhuǎn)實(shí)現(xiàn)div局部?jī)?nèi)容變更
if ("doQueryRequest".equals(actParam)) {
EquipUtils equipUtilsObj = EquipUtils.getInstance();
//取查詢(xún)參數(shù)、拼接
equipStatusMgrObj.setEquipCondition(equipUtilsObj.createEquipFilter(request));
equipStatusMgrObj.setEquipStatusCondition(equipUtilsObj.getEquipStatusDate(request));
//設(shè)備信息
List<DynaBean> equipArray = equipStatusMgrObj.queryEquip(null);
//設(shè)備狀態(tài)
Map<String, Map<String, String>> equipStatusMapping =
equipStatusMgrObj.queryEquipState4Map(equipArray, null);
sessionObj.setAttribute("paginationEntity", equipStatusMgrObj.getPaginationEntity());
sessionObj.setAttribute("equipCondition", equipStatusMgrObj.getEquipCondition());
sessionObj.setAttribute("eqStatusCondition", equipStatusMgrObj.getEquipStatusCondition());
request.setAttribute("equipList", equipArray);
request.setAttribute("dateList", equipStatusMapping);
try {
request.getRequestDispatcher("/eq/detectPoint/InnerEqStatusRefresh.jsp").forward(request, response);
} catch (Exception e) {
e.printStackTrace();
}
} else if ("getPageToolBar".equals(actParam)) {
PaginationEntity pEntity = (PaginationEntity) sessionObj.getAttribute("paginationEntity");
String tempStr = pEntity.getPaginationTool();
OutputStream out;
try {
response.setContentType("text/html;charset=UTF-8");
out = response.getOutputStream();
out.write(tempStr.getBytes("UTF-8"));
out.flush();
out.close();
} catch (IOException e) {
e.printStackTrace();
}
}
因?yàn)椋壳笆褂脁mlHttpObj.responseText,responseText默認(rèn)就是UTF-8所以將跳轉(zhuǎn)的頁(yè)面弄成UTF-8是不錯(cuò)的選擇。至少不用擔(dān)心亂碼。。
[亂碼原因]
之前此功能使用的是GB18030編碼,到修改為止在其它客戶(hù)機(jī)以及同事的機(jī)器上都非常正常,但就是我自己的機(jī)器翻頁(yè)出現(xiàn)亂碼。當(dāng)我將此功能所用到的呈現(xiàn)文件統(tǒng)一使用UTF-8就ok了,也不知那xmlHttpObj觸動(dòng)了機(jī)器的那個(gè)神經(jīng)。。查了些資料也都是說(shuō)搞國(guó)際化的趨勢(shì),問(wèn)題是解決了但原因沒(méi)有找到!
[發(fā)現(xiàn)一Bug]
response.setContentType("text/html;charset=UTF8");在我機(jī)器上不拋錯(cuò),但在同事的機(jī)器上就會(huì)拋錯(cuò)
改成response.setContentType("text/html;charset=UTF-8");一切OK..
- Ajax中responseText返回的是一個(gè)頁(yè)面而不是一個(gè)值
- ajax的responseText亂碼的問(wèn)題的解決方法
- jquery ajax學(xué)習(xí)筆記2 使用XMLHttpRequest對(duì)象的responseXML
- Ajax Throws Sys.WebForms.PageRequestManagerErrorException with Response.Redirect的解決方法
- ajax的 responseXML返回接受 asp
- 關(guān)于Ajax中通過(guò)response在后臺(tái)傳遞數(shù)據(jù)問(wèn)題
相關(guān)文章
ajax接收Date類(lèi)型的數(shù)據(jù)時(shí)會(huì)把數(shù)據(jù)轉(zhuǎn)換為時(shí)間戳
ajax接收Date類(lèi)型的數(shù)據(jù)時(shí)將會(huì)把數(shù)據(jù)轉(zhuǎn)換為時(shí)間戳,下面是具體的示例,大家可以參考下2014-05-05Ajax實(shí)現(xiàn)列表無(wú)限加載和二級(jí)下拉選項(xiàng)效果
這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)列表無(wú)限加載和二級(jí)下拉選項(xiàng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06基于HTML5 Ajax文件上傳進(jìn)度條如何實(shí)現(xiàn)(jquery版本)
本文給大家介紹基于html5 ajax文件上傳進(jìn)度條是如何實(shí)現(xiàn)的,涉及到html5新增加的formdata對(duì)象的使用,對(duì)html5文件上傳進(jìn)度條感興趣的朋友一起學(xué)習(xí)吧2015-11-11關(guān)于Ajax技術(shù)原理的3點(diǎn)總結(jié)
這篇文章主要介紹了關(guān)于Ajax技術(shù)原理的3點(diǎn)總結(jié),需要的朋友可以參考下2014-12-12JQuery ajax 返回json時(shí)出現(xiàn)中文亂碼該如何解決
最近有朋友反映使用jquery.ajax調(diào)用返回json時(shí)出現(xiàn)中文亂碼,遇到此問(wèn)題,非常棘手,下面小編幫大家解決JQuery ajax 返回json時(shí)出現(xiàn)中文亂碼問(wèn)題,感興趣的朋友跟著一起了解了解吧2015-09-09Ajax學(xué)習(xí)全套(最全最經(jīng)典)
ajax是指一種創(chuàng)建交互式網(wǎng)頁(yè)應(yīng)用的網(wǎng)頁(yè)開(kāi)發(fā)技術(shù)。這篇文章主要介紹了Ajax學(xué)習(xí)全套(最全最經(jīng)典)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08防止重復(fù)發(fā)送Ajax請(qǐng)求的解決方案
這篇文章主要介紹了防止重復(fù)發(fā)送Ajax請(qǐng)求的解決方案,感興趣的小伙伴們可以參考一下2016-01-01淺析Ajax后臺(tái)success傳來(lái)json數(shù)據(jù)的問(wèn)題
最近在使用JQuery的ajax方法時(shí),需要返回的數(shù)據(jù)為json數(shù)據(jù),在success返回中數(shù)據(jù)處理會(huì)根據(jù)返回方式不同會(huì)采用不同的方式來(lái)生成json數(shù)據(jù)。下面小編給大家介紹下在$.ajax方法中應(yīng)該是如何來(lái)處理的2016-10-10