关于后台请求接收参数乱码问题
来源:互联网 发布:linux 桌面 2017 编辑:程序博客网 时间:2024/05/16 04:20
前台<a href="http://blog.163.com/jiao_xia_ke_super/blog/${basePath}problem/searchByCondition.action?type=中国"></a>,后台接收参数后出现乱码,这种问题是前后编码方式不同,解决方法如下:
前台两次编码,后台一次解码
前台两次编码,后台一次解码
后台解码如下:<script type="text/javascript">
function sub(){
var name = $("#test").val();
var type = encodeURI(encodeURI(name));
$("#a").attr("href","${basePaht}problem/searchByCondition.action?type="+type);
}
</script><body>
<input type="text" id="test" value="中国"/>
<a href="http://blog.163.com/jiao_xia_ke_super/blog/." onClick="sub();" id="a">点击此处</a>
</body>
temp2结果为:中国String type = request.getParameter("type");
String temp2 = java.net.URLDecoder.decode(type,"UTF-8");
其中具体的原理分析如下,假设页面端输入的中文是一个“中”,按照下面步骤进行解码
1.第一次encodeURI,按照utf-8方式获取字节数组变成[-28,-72-83],对字节码数组进行遍历,把每个字节转化成对应的16进制数,这样就变成了[E4,B8,AD],最后变成[%E4,%B8,%AD]
2.第二次encodeURI,把数组最后变成[%25E4,%25B8,%25AD]然后就把处理后的数据[%25E4,%25B8,%25AD]发往服务器端,
当应用服务器调用getParameter方法,getParameter方法会去向应用服务器请求参数
应用服务器最初获得的就是发送来的[%25E4,%25B8,%25AD],应用服务器会对这个数据进行URLdecode操作,URldecode操作和encodeURL操作是相反的操作,处理结果就是[%E4,%B8,%AD],并把这个值返回给getParameter方法
然后再在服务器端中调用相应的URL转码方法或者是函数 就可以把数据还原成最初页面发送过来的中文“中”了。
阅读全文
0 0
- 关于后台请求接收参数乱码问题
- 关于struts2.1.6接收中文请求参数乱码问题
- AJAX请求URL中带入中文参数,后台接收乱码问题
- 关于JSF后台属性接收参数问题
- js中关于get请求(包括异步以及直接用过网页连接请求),后台接收乱码问题
- 服务器接收到的请求参数乱码问题
- 关于请求参数中文乱码的问题
- 关于请求参数中文乱码的问题
- 关于前端传参数,后台接收的问题
- Volley get请求上传中文参数,后台接收到的是乱码的解决办法
- Volley get请求上传中文参数,后台接收到的是乱码的解决办法
- 关于php接收IE地址栏参数乱码问题
- angularJS post请求后台接收不到参数
- ajax提交参数,后台接收乱码
- 关于ajax请求 后台返回中文数据乱码问题
- 关于浏览器的请求数据到达后台乱码问题
- Spring 接收参数乱码问题
- ajax /get 请求,服务器端接收参数乱码
- AvalonJs入门二 复选框全选反选+layui分页
- JavaScript学习之路<二>
- 【JavaScript】全国城市三级联动
- JavaScript学习之路<四>
- ubuntu16.04配置tomcat环境
- 关于后台请求接收参数乱码问题
- Java 堆和栈
- JavaScript学习之路<五>
- Java___js
- JavaScript学习之路<六>
- JQuery点击按钮 数字递增递减
- JavaScript学习之路<七>
- C++复合类型(二)
- replace,replaceAll,replaceWith的区别