日期:2014-05-16  浏览次数:20789 次

vc传输字符===>java servlet====>hibernate====>mysql乱码问题

前提:vc2008项目的内码设置为UNICODE,mysql数据表的文本字段编码为utf-8

一.vc到java servlet乱码问题
1. 首先在vc中,WideCharToMultibyte(CP_UTF_8,...
转换的结果和在UE编辑器中转换的结果是一致的,至于为何显示为乱码,这个是文本渲染器的问题,和WideCharToMultibyte本身没有关系。

2.VC中IXMLHttpRequest.send函数发送UTF-16字符串,到了java编写的servlet的时候,字符编码变了,如果传输的是

GBK编码,则会自动变为utf-8编码,如果传的是utf-8就转变成了乱码(当然肯定是一种编码,只是这里不细

究)

3.对此要解决问题的方法也就是发送数据流了,不能发送字符串了,否则总有地方给你变了,具体解决方案是发送裸数据流。

 

VC的做法是:
实现IStream类,将IStream接口给xmlhttp::send(*),当然实现IStream类主要实现read函数就可以了。

注意:字符发送过去后,如果传输的UTF16字符流,要用UNICODE小尾编码方式反解。最好最终转码为utf-8编码(保存和java内码一致)

二.java servlet-->hibernate--->mysql数据库.乱码问题
1.设置hibernate配置文件编码
<property name="connection.useUnicode">true</property>
<property name="connection.characterEncoding">UTF-8</property>