您好,欢迎访问一九零五行业门户网

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

为了规范 我们使用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页面的显示 都没问题了
很是希望以上的办法能够帮助到与我一样陷入乱码痛苦的码农们 在下才疏学浅 如果你觉得有帮助 那是我的荣幸  如果你觉得没帮助 也请别喷
如果说以上的一些说法有问题 恳请广大网友指正 小弟感激不尽!
其它类似信息

推荐信息