Java Web开发中文乱码问题

版权声明:本文为 Codeagles 原创文章,可以随意转载,但必须在明确位置注明出处!!!

对于刚开始接触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项目中乱码常见问题以及出现问题为位置都可以搞定了。如果后续遇到上述办法解决不了的,会继续更新文章指出。



复制代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值