欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

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

程序员文章站 2022-04-25 16:30:07
...

为了规范 我们使用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文件中的第一句 加上“ ”


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

jsp文件中添加这句

同时为了保险 在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之前就指定编码

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


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


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