编码问题

1、创建数据库的时候要选好一种支持中文的编码,可以选GBK、GB2312、UTF-8,选好后其他地方的编码都尽量与这里的一样,这里就以UTF-8为例说明。

2、在进行JSP页面代码区,将页面中凡是涉及到编码的地方都设置成与上述数据库同一编码。为了避免不同浏览器支持不同编码的问题,可以在每个页面的开始处(可以放在<head>标签前面)都加一条设置请求代码的编码,具体如下:

<%

request.setCharacterEncoding("utf-8");

%>

这样就能保证对发送的请求按照设置好的编码传过来,这解决了页面直接传递中文时出现乱码的问题,以下则解决插入数据库时乱码的问题。

3、当页面的编码和数据库的编码都相同的时候,就能保证中文数据传过来是正确的,但要保证插入时也正确,还要设置连接数据库时的编码。具体语句如下(连接的是MySQL数据库):

public class DB {

public static Connection getConnection(){
String user = "root"; //连接数据库时的用户名
String password = "root"; //连接数据库时的密码
String url = "jdbc:mysql://localhost:3306/db_name?useUnicode=true&characterEncoding=utf-8"; //加上这部分有关编码设置的代码
String driver = "com.mysql.jdbc.Driver";
Connection con = null;
try {
Class.forName(driver);
con = DriverManager.getConnection(url, user, password);
} catch (Exception e) {
e.printStackTrace();
}
return con;
}

}

4、需要修改MySQL数据库的配置文件my.ini,此文件放在mysql根目录下。在此文件下查找default-character-set属性,并将其值更改为utf8(注意:不是utf-8,也要注意大小写),这里需要将default-character-set属性全部属性的值修改为utf8。示例:
default-character-set = utf8
提示:default-character-set属性有两个,一个在[mysql]下面,另外一个在[mysqld]下面。



(对hibernate)
5、同时创建hibernate数据库时需要显示设置数据库的编码方式为utf8。示例:
create database daycode default charset=utf8;


6、做完这两步还是不行,需要修改hibernate的配置文件hibernate.cfg.xml,在配置文件配置hibernate.connection.url属性。示例:
<property name="hibernate.connection.url">
        <![CDATA[jdbc:mysql://localhost:3306/daycode?useUnicode=true&characterEncoding=utf8]]>
</property>

注意:此字符串不能写为jdbc:mysql://localhost:3306/daycode?useUnicode=true&characterEncoding=utf8,不然会出现编译错误,错误提示为将&连接符改为;。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值