<big>版权声明:本文为 Codeagles 原创文章,可以随意转载,但必须在明确位置注明出处!!!</big>
对于刚开始接触JavaWeb项目的新鸟来说,乱码一直都是个头疼的问题,不清楚EL表达式取值为什么会乱,不知道为什么jsp显示会乱码,明明显示jsp中取值正常,传到后台用java取值又乱了。那么本文可以说是解决了常见的乱码问题。
乱码常见地方如下:
- jsp页面中。EL表达式或者直接取值,哪怕写个固定的中文显示都会乱。
- java代码。前端到后端传输值,乱码。
- 数据库的编码格式。数据库编码格式不统一,导致插入数据库的时候也会出现乱码。
- 文件编码格式。一般在IDE中就可以设置。
- Servlet容器—Tomcat。在运行jsp需要借助Tomcat,那么还需要将Tomcat进行编码格式设置。
理解了这几个常见地方,就对症下药更改编码格式就OK了,我们统一编码为UTF-8。
- jsp页面编码。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
只要写jsp的都不陌生,更改页面的字符集。
- java后台代码。
如果是java web项目,那么可以对应在post和get方式获取值的时候设置编码格式。- POST方式
request.setCharacterEncoding("utf-8");
- GET方式
request.setCharacterEncoding("utf-8");
//例如获取页面的username值进行转换
String username =new String(request.getParameter("username").getBytes("iso8859-1"),"utf-8");
- 数据库编码。
该编码一般来说比较简单。为了避免出现问题,我们可以注意两个地方,用Mysql举例来说。-
第一种,在创建数据库的时候,将编码设置好。
- 第二种,在代码的数据库连接url中填写编码格式。这个方式适用于Mysql数据库,其他数据库用第一种在本地设置编码也可。
-
<!-- 数据库连接池,由 Mybatis 管理,数据库名是 mybatis,MySQL 用户名 root,密码为root -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8" />
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
-
文件编码。文件编码比较简单,进入到IDE中,右键项目->Properties
基本上可以解决乱码问题。当然从外部导入项目时,与环境编码不一样也会导致错误,用该方法依然可以解决。
-
Tomcat编码。此处也是最为重要的,一般页面编码,java编码都设置过(甚至建立一个web工程,但是没有jsp到Java的取值过程,如建立java类创建main方法,输出中文,运行都会乱码),此时还乱码就需要设置Tomcat编码格式。找到Tomcat安装文件夹->conf文件夹->server.xml
打开xml文件,大约70行左右。原文件是没有红色框中```
URIEncoding="UTF-8"
![Tomcat编码](http://upload-images.jianshu.io/upload_images/3305482-4b8205a529d4b005.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
至此,web项目中乱码常见问题以及出现问题为位置都可以搞定了。如果后续遇到上述办法解决不了的,会继续更新文章指出。