尽量用post提交,不要用问号拼接参数的方式,就不会乱码了
原文:http://blog.csdn.net/wzygis/article/details/50964864
在Java 开发中,如果框架搭建的不完善或者初学者在学习过程中,出现中文乱码是经常的事儿(哈。谁让发明Java语言的不是中国人呢)
今天跟大家分享几个解决java Web开发中,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
<Connector URIEncoding="UTF-8" acceptCount="1500" connectionTimeout="20000" enableLookups="false" maxSpareThreads="100" maxThreads="1000" minSpareThreads="25" port="9082" protocol="HTTP/1.1" useBodyEncodingForURI="true"/>
重点在 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数据库后就是乱码了。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-8
username=root
password=brozer
initialSize=5
maxIdle=10
maxTotal=50
maxWaitMillis=5000
minIdle=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
web项目存数据到数据库,中文乱码,解决过程
first:
排查原因:
打断点,查看到底是在执行存数据库操作之前就已经乱码了,还是存数据库操作后乱码的。
前者解决方案:
在web.xml里面加上:
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<async-supported>true</async-supported>
<init-param:>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
在配置jdbc数据源的时候加上:
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