Ajax传递的数据包含特殊字符时的解决方法
程序员文章站
2024-01-05 17:45:28
Ajax传递的数据包含特殊字符时的解决方法
问题描述
如下,对含有特殊字符的text进行JSON封装,通过Ajax传递,
var data = {"Id&quo...
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"));
这样就可以正确的进行文本的接收啦~
上一篇: 网站注册用户密码储存问题
下一篇: Android 进程间通信
推荐阅读
-
infobright导入数据遇到特殊字符报错的解决方法
-
infobright导入数据遇到特殊字符报错的解决方法
-
SQL去除数据库表中tab、空格、回车符等特殊字符的解决方法
-
SQL去除数据库表中tab、空格、回车符等特殊字符的解决方法
-
jQuery ajax传入参数含有特殊字符的解决方法
-
如何利用jQuery ajax post传递含特殊字符的数据
-
关于smarty取oracle数据数组后传递时,只取每个字段第一个字符的有关问题
-
DW中链接mysql数据库时,建立字符集中文出现乱码的解决方法
-
关于smarty取oracle数据数组后传递时,只取每个字段第一个字符的问题
-
Ajax传递的数据包含特殊字符时的解决方法