当前位置:Gxlcms > mysql > Servlet+JSP+MySQL5.6模式下开发web应用出现的中文乱码处理

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

时间:2021-07-01 10:21:17 帮助过:19人阅读

为了规范 我们使用UTF-8编码为例 我用的web开发软件是 MyEclipse8.5 MySQL5.6 tomcat7 1.弄明白一个web应用从数据库到jsp页面可能经历了哪几层编码的转化 大致是以下的流程 浏览器解释jsp文件所用的编码 - jsp,java文件等等本身的编码 - request接受数据 传

为了规范 我们使用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文件里面 找到

connectionTimeout="20000"
redirectPort="8443" /> 改为

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页面的显示 都没问题了


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


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




人气教程排行