Servlet+JSP+MySQL5.6模式下开发web应用出现的中文乱码处理

为了规范 我们使用UTF-8编码为例 我用的web开发软件是 MyEclipse8.5  MySQL5.6  tomcat7


1.弄明白一个web应用从数据库到jsp页面可能经历了哪几层编码的转化 大致是以下的流程


 浏览器解释jsp文件所用的编码  <->    jsp,java文件等等本身的编码  <->  request接受数据 传递数据时所用的编码 或者是form表单提交数据所用的编码  <-> Tomcat服务器接受数据时用的编码 <-> Tomcat服务器传递数据给Servlet所用的编码 <-> 在servlet中使用sql语句的编码(一般与java文件本身的的编码一致) <-> 数据库中存储数据使用的编码


 2.现在说说怎么去设置每个流程的编码


①.浏览器解释jsp文件所用的编码  

在servlet文件中 doGet()方法的第一句应该为这条语句"response.setContentType("text/html;charset=utf-8");" doPost()方法应该为 this.doGet() 

在jsp文件中的第一句 加上“ <%@ page language="java" contentType="text/html; charset=UTF-8"%>”  


②.jsp.java文件等等本身的编码

  jsp文件中添加这句“<%@ page language="java"  pageEncoding="utf-8"%>

同时为了保险  在MyEclipse中做一些设置 

首先对你的web工程名右键选择properties -> Resource -> 选择Text file encoding为UTF-8

然后Window -> Preferences -> MyEclipse -> Files and Editors 把所有的与你的web工程有关的文件比如jsp css xml 的编码全部设置为 ISO 10640/Unicode(UTF-8)

③.request接受数据 传递数据所用的编码 (这个说实话我并没有指定也解决了中文乱码)  但为了保险 我还是把方法写在这里

所有的servlet 文件里面的doGet方法的第一句为request.setCharacterEncoding("UTF-8"); 与前面说的稍有冲突 但基本无影响 doPost()方法应该为 this.doGet()

所有的jsp文件也是一样 在用到request之前就指定编码<% request.setCharacter("UTF-8"); %>

至于form表单提交时的编码问题 我并没有指定

④.Tomcat服务器接收数据时所用的编码

这个很简单 在Tomcat目录下的server.xml文件里面 找到

       <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />  改为

<Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" URIEncoding="UTF-8" /> 

⑤.sql语句的编码与数据库存储数据时指定的编码

网上大多数人都说 为了编码一致 必须在mysql数据库中所有的地方都要使用一样的编码 如UTF-8  于是就要这样做  mysql> set names 'UTF-8'; 还有的人说 在my.ini里面 设置默认编码为UTF-8 当然这个是以前的MySQL版本了 MySQL5.6是没有my.ini这个文件的  至少我没找到

诚然 以上的办法也许能够解决问题 但不幸的是 在我这里确实无法解决

但根据我自己的理解来说 

这里存在一个问题 当你右键控制台窗口 选择默认值的时候 默认代码页是没有UTF-8的 只有 437 OEM 美国 和 GBK 这里无法保证编码的统一性 

如果使用set names 这样的sql语句指定编码一致的话  会出问题 

然后 那又该如何解决? 首先确保你的默认代码页是GBK  

使用sql语句 mysql>show variables like 'character_set_%'; 查看mysql字符集

    确保结果是这样

mysql> show variables like 'character_set_%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | gbk                       |
| character_set_connection | gbk                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | gbk                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+


如果不是 请使用sql语句 形如 mysql> set character_set_client=gbk; 这样来逐个修改编码


经过以上的修改 请重启tomcat服务器 mysql数据库 


我的数据库 jsp页面的乱码就这样实实在在的解决了 无论是jsp页面插入中文数据到数据库 还是从数据库中提取数据到jsp页面的显示 都没问题了


很是希望以上的办法能够帮助到与我一样陷入乱码痛苦的码农们 在下才疏学浅 如果你觉得有帮助 那是我的荣幸  如果你觉得没帮助 也请别喷 


如果说以上的一些说法有问题 恳请广大网友指正 小弟感激不尽!








猜你喜欢

转载自blog.csdn.net/wuyanxue/article/details/9530181