您好,登錄后才能下訂單哦!
這篇文章主要介紹“jquery ajax utf-8亂碼如何解決”,在日常操作中,相信很多人在jquery ajax utf-8亂碼如何解決問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”jquery ajax utf-8亂碼如何解決”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
jquery ajax utf-8亂碼的解決辦法:1、設置contentType的編碼為“utf-8”,代碼為“contentType: "application/x-www-form-urlencoded;charset=utf-8"”;2、在獲取PrintWriter對象之前設置“resp.setContentType("text/text;charset=GBK");”。
1. jQuery AJAX 請求后臺收到為亂碼
可以顯式設置contentType的編碼為utf-8, 后臺一般都能正常解碼例如:
contentType: "application/x-www-form-urlencoded; charset=utf-8",
jQuery(form).ajaxSubmit({
url: "doLogin?user=a",
type: "post",
dataType: "json",
contentType: "application/x-www-form-urlencoded; charset=utf-8",
success: showLoginResponse
});
如果不加contentType: "application/x-www-form-urlencoded; charset=UTF-8", 而使用escape(),則會出現
“post 主體包含的字節比內容長度指定的字節要少”
的錯誤.
2. jQuery AJAX 返回亂碼
你是否發現無論你怎么設置編碼, 客戶端收到的數據總是亂碼呢, 請看下面的例子,你發現有什么問題嗎?
void saveTempKind(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
PrintWriter pw = resp.getWriter();
resp.setContentType("text/text;charset=GBK");
try {
//DO PROCESS
pw.write("成功");
}catch(Exception e){
pw.write("失敗");
}
}
問題在于resp.setContentType("text/text;charset=GBK"); 語句應該在
PrintWriter pw = resp.getWriter();
之前,而不是之后。如果象上例這樣,無論你怎么設置response的編碼,前端亂碼的問題都依然如故。 可能的原因是pw在獲得PriintWriter 之前,編碼就已經確定了。所以編碼的聲明應該在獲取PrintWriter對象之前。
到此,關于“jquery ajax utf-8亂碼如何解決”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。