java - url解码出错
问题描述
问题:安卓向后台server发送的中文,解码是乱码。。
环境:
1. tomcat,在server.xml中已经明确了“utf-8'.2. 安卓已经明确了使用Utf-8编码3. 在后台使用` java.net.URLDecoder.decode(url, 'utf-8');`对url进行解码,但是解码出错。。中文是”??“。
应该是编码问题啊,,但是。。。
万分感谢。。。
另外,我使用如下语句测试编码:
if (url.equals(new String(url.getBytes('iso8859-1'), 'iso8859-1'))) { url = new String(url.getBytes('iso8859-1'), 'utf-8'); System.out.println('ios8859-1');}if (url.equals(new String(url.getBytes('GB2312'), 'GB2312'))) { url = new String(url.getBytes('GB2312'), 'utf-8'); System.out.println('gb2312');}
输出
ios8859-1gb2312
。。。。
问题解答
回答1:后台的有没有加入编码过滤器?
回答2:URLEncode/Decode 是针对 URL 里面的参数值,避免与 URL 格式本身发生冲突。Tomcat 会自动解码 URL 参数值,所以你只需要直接获取就好。例如下面这个 JSP:
<%@ page import='java.net.URLEncoder' %><%@ page contentType='text/html;charset=UTF-8' language='java' %><% System.out.println('name=' + request.getParameter('name'));%><a href='https://www.haobala.com/wenda/?name=<%=URLEncoder.encode('你好', 'UTF-8')%>'>你好</a><a href='https://www.haobala.com/wenda/?name=你好'>你好</a>
实际上两个“你好”链接是没有区别的,你可以打开网页源代码看到它们链接地址,一个有编码一个没有,但点击之后,控制台都能输出正确的值,也就是说 request.getParameter('name') 得到的内容是完全一样的。
相关文章:
1. 运维 - java tomcat多个小项目共存问题2. javascript - swiper插件loop模式下的BUG?3. javascript - sublime快键键问题4. node.js通过module.exprots返回的是promise对象而非data?5. dockerfile - 为什么docker容器启动不了?6. docker gitlab 如何git clone?7. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””8. 把h5放入webview里面,h5页面上下可以回弹,怎么可以去掉该效果9. mysql - sql 左连接结果union右连接结果,导致重复性计算怎么解决?10. javascript - 想做一个canvas的触摸画板,但屏幕会在画的时候滚来滚去,如何阻止?

网公网安备