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 - 阿里的开发手册中为什么禁用map来作为查询的接受类?2. python - Flask 脚本,运行一段时间后无响应3. javascript - 如何在外部点击,跳转到网页后,显示指定的模块。4. html5 - 如何禁止百度转码?5. css - 关于background-position百分比的问题?6. java - Spring boot项目 可以通过ip+port+contentPath就直接显示所有的接口地址和数据信息,这是为什么???7. javascript - 微信开发遇到的问题8. python - 如何用pandas处理分钟数据变成小时线?9. html5 - 如何解决微信网页偶尔出现的乱码问题?10. MySQL创建表存在的问题

网公网安备