這篇文章為大家介紹了Ajax傳遞的資料包含特殊字元時的解決方法,需要的朋友參考下吧
問題描述
#如下,對含有特殊字元的text進行JSON封裝,透過Ajax傳遞,
var data = {"Id": id, "text": text};
在後台無法進行資料接收。
解決方案
將
req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
換成:
req.setRequestHeader("Content-type", "application/json; charset=utf-8");
後台接受資料:
//进行json数据的接收 StringBuilder sb = new StringBuilder(); BufferedReader br = request.getReader(); char[] buff = new char[10000]; int len; while((len = br.read(buff)) != -1){ sb.append(buff, 0, len); } String mess = sb.toString(); //将字符串转换为JSON对象 JSONObject jsonObject=new JSONObject(mess); //获取其中的值 jsonObject.getInt("Id"); //含有特殊字符的文本需要先进行转码 URLDecoder.decode(jsonObject.getString("text"), "UTF-8"));
這樣就可以正確的進行文本的接收啦~
上面是我整理給大家的,希望今後會對大家有幫助。
相關文章:
使用Ajax或Easyui等框架時的Json-lib的處理方案(圖文教學)
#以上是Ajax傳遞特殊字元的資料如何解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!