尽量用post提交,不要用问号拼接参数的方式,就不会乱码了
原文:http://blog.csdn.net/wzygis/article/details/50964864
在 开发中,如果框架搭建的不完善或者初学者在学习过程中,出现中文是经常的事儿(哈。谁让发明语言的不是中国人呢)
今天跟大家分享几个解决java 中,request.getParameter()获取URL中文参数乱码的解决办法
解决问题,先要研究问题,URL传中文参数为什么会出现乱码?
原因:Http请求传输时将url以ISO-8859-1编码,服务器收到字节流后默认会以ISO-8859-1编码来解码成字符流(造成中文乱码)
解决办法:我们需要把request.getParameter(“参数名”)获取到的字符串先用ISO-8859-1编码成字节流,然后再将其用utf-8解码成字符流
代码:
String str = new String(request.getParameter("参数名").getBytes("iso-8859-1"), "utf-8");
这是通过转码的方式处理乱码问题,我们也可以通过Tomcat配置文件,设置URL编码集(URIEncoding)设置编码,这种方法也是一劳永逸的,
修改Tomcat/conf 目录下 server.xml
重点在 userBodyEncodingForURI 和 URIEncoding 这两个属性
下面来解释一下这两个属性的意义
useBodyEncodingForURI参数表示是否用request.setCharacterEncoding参数对URL提交的数据和表单中GET方式提交的数据进行重新编码,在默认情况下,该参数为false。
URIEncoding参数指定对所有GET方式请求进行统一的重新编码(解码)的编码。
URIEncoding和useBodyEncodingForURI区别是,
URIEncoding是对所有GET方式的请求的数据进行统一的重新编码,
而useBodyEncodingForURI则是根据响应该请求的页面的request.setCharacterEncoding参数对数据进行的重新编码,不同的页面可以有不同的重新编码的编码。
原文:http://blog.csdn.net/lixuanshengchao/article/details/51521005
今天做一个项目遇到一个问题,在myeclipse里面调试的时候,里面的数据不是乱码,但是插入到后就是乱码了。mysql的my.ini文件设置的是utf8,这些都没得问题,但是插入数据库还是乱码。
最后还是找到了解决办法。在连接数据库类里面的url参数设置如下:
jdbc:mysql://localhost:3306/zhuojh?useUnicode=true&characterEncoding=UTF-8
在后面加上这两个参数。就不是乱码了。
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/enterprise?useUnicode=true&characterEncoding=UTF-8username=rootpassword=brozerinitialSize=5maxIdle=10maxTotal=50maxWaitMillis=5000minIdle=5
页面加上编码设置
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
原文:http://blog.csdn.net/cc_yy_zh/article/details/51559742
客户端向服务器端发送信息,如果发送的编码和服务器端接收的编码不一样,使用request.getParameter()方法获取的表单信息会产生乱码。客户端接收服务器的响应信息,如果响应编码与客户浏览器的编码不一致时,会造成中文乱码显示。
为了解决中文正常显示,可以采取以下方案。 (1)post方式提交表单 a>设置页面的编码 在jsp或HTML页面中,有时会涉及编码的定义,可使用统一编码,例如GBK或UTF-8. b>设置表单提交方式在页面中,将 标记的method属性值设置为post,该属性默认为get,get方式会将表单信息采取特殊编码,然后借助于URL发送给服务器。 c>设置服务器接收编码 在使用request.getParameter()方式接收客户表单信息之前,设置接收编码,编码与页面保持一致。request.setCharacterEncoding(“UTF-8”); 使用setCharacterEncoding()方法指定编码后,可以通过getParameter()方法按指定编码获得客户信息,如果不指定,则默认使用ISO-8859-1编码。下面比较强硬了
String str = new String(request.getParameter(“参数名”).getBytes(“iso-8859-1”), “utf-8”);
原文:http://www.cnblogs.com/tom-plus/p/5701741.html
first:
排查原因:
打断点,查看到底是在执行存数据库操作之前就已经乱码了,还是存数据库操作后乱码的。
前者解决方案:
在web.xml里面加上:
encodingFilter org.springframework.web.filter.CharacterEncodingFilter true encoding UTF-8 在配置jdbc数据源的时候加上: encodingFilter /*
jdbc:mysql://127.0.0.1:3306/logistics?useUnicode=true&characterEncoding=UTF-8 存数据库操作后乱码,解决方案: 登录数据库,执行如下sql:
show variables like 'character%';
结果:
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 |
说明在安装数据库的时候,character_set_database,character_set_server编码格式设置错误。
解决:
找到mysql安装路径下的my.cnf文件在[mysqld]下添加如下两行:
character_set_server=utf8
init_connect='SET NAMES utf8'再次查看,问题解决:
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8