个人心得
这次完整的只用JSP去完成这次有关JDBC链接数据库,真的收获很多,因为最开始学Javaweb学的也不是很认真,然后后面学了框架之后,自己都不用管太多编码的问题,那些东西,框架里面都是设置好的,然后这次Javaweb的普通的项目真的恶心到我了,然后现在UTF-8比较流行,我就以weiUTF-8为例,想要不乱码,那么就把所有的编码统一。
1:检查JSP的编码是否为UTF-8
<%@ page contentType="text/html;charset=UTF-8" language="java" pageEncoding="UTF-8"%>
2:form表单设置UTF-8
<form name="form" method="post" action="verify.jsp" accept-charset="UTF-8">
3:编译器的编码设置为UTF-8
我用的编译器是idea,我就以idea为例来设置
4:tomcat的请求转发的编码设置
这个其实最难受的一个,我最开始所有的都设置了,但是还是插入数据乱码,原来是tomcat转发的时候的编码默认是iso-8859-1,而我们用的是UTF-8,所以出了问题。
Http请求传输时将url以ISO-8859-1编码,服务器收到字节流后默认会以ISO-8859-1编码来解码成字符流(造成中文乱码)。
解决办法:我们需要把request.getParameter(“参数名”)获取到的字符串先用ISO-8859-1编码成字节流,然后再将其用utf-8解码成字符流。
- 解决办法一:将表单中的中文字符串取出来的时候转码一下
String name = new String(request.getParameter("name").getBytes("iso-8859-1"), "utf-8");
- 解决办法二:这个比较强大就是,设置全局的转发请求的编码集,设置tomcat的conf/server.xml中一些东西
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8444"
useBodyEncodingForURI="true" URIEncoding="UTF-8"/>
重点在 userBodyEncodingForURI 和 URIEncoding 这两个属性。
下面来解释一下这两个属性的意义:
useBodyEncodingForURI参数表示是否用request.setCharacterEncoding参数对URL提交的数据和表单中GET方式提交的数据进行重新编码,在默认情况下,该参数为false。
URIEncoding参数指定对所有GET方式请求进行统一的重新编码(解码)的编码。
URIEncoding和useBodyEncodingForURI区别是:
URIEncoding是对所有GET方式的请求的数据进行统一的重新编码,
而useBodyEncodingForURI则是根据响应该请求的页面的request.setCharacterEncoding参数对数据进行的重新编码,不同的页面可以有不同的重新编码的编码。
- 解决办法三:利用request.setCharacterEncoding(“UTF-8”);来设置Tomcat接收请求的编码格式,只对POST方式提交的数据有效,对GET方式提交的数据无效!
最后的最后,提一个小细节:URL地址后面如果跟了中文数据,一定要经过URL编码。表单提交的参数有中文数据,浏览器会自动帮我们编码,但如果是通过链接直接带中文参数,浏览器是不会帮我们编码的,这时想通过上述第一种方式解决中文乱码问题就时灵时不灵了,应该通过URLEncoding.encode(,“UTF-8”)先编码。
5:数据库的编码也要检查
还有链接数据库的url设置
String uri= "jdbc:mysql://IP地址:3306/数据库名?useUnicode=true&characterEncoding=utf-8