mysql 5.5.15编码导致数据库中写入汉字出错的解决方法

今日在一台新的win2008 r2的新服务器上调试tomcat+jdk+mysql,使用utf-8编码,出现了非常郁闷的事,无论如何写入数据库中的字段数据老是出现乱码。

已经调整内容:

1、在接收post消息的文件内已经修改了:

<%@ page contentType="text/html;charset=utf-8" pageEncoding="utf-8"%>

2、<head>段中已经修改为:

<meta http-equiv="Content-Type" contect="text/html" charset=utf-8"  >

3、在每个使用request.getParameter()的文件前加上了一下代码:

request.setCharacterEncoding("utf-8");

4、每个代码文件都改为utf-8编码。

5、mysql表中对应表已改为utf8编码,utf8_general_ci编码。

6、tomcat下的server.xml已更改为:

<Connector port="80" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" URIEncoding="utf-8" useBodyEncodingForURI="true"/>

结果写入的字段仍然为乱码,读出的代码也为乱码,非常的郁闷,最后只差进行代码强制转换了。

但是考虑到只是作为这个项目的专一服务器,因此没有。最后无意中发现,需要更改mysql安装文件下的my.ini中的

# CLIENT SECTION中的

default-character-set=latin1

default-character-set=utf8

并且

# SERVER SECTION中的

character-set-server=latin1

character-set-server=utf8

即可解决问题。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lwprain

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值