那首先要调查清楚,数据表的编码,看清,不是数据库,是表,表的字符集编码。
然后往前顺。
然后再java程序中转码,保证写到sql中的数据是以该数据表所用的字符集编码的就好了。
乱码出现在不同部分的通信之间
一个系统中,通常是在显式输入中文的地方发生转码错误。
比如,servlet处理从浏览器传来的数据的时候,
从资源文件读取数据的时候。
在程序中显式地硬编码字符串中文字面值的时候。
从别人的数据库读取数据的时候。
这些地方经常会跟之后的系统编码不一致,所以在这些地方使用字符串数据的时候,就要转码。
资源文件,可以用文本工具保存成需要的编码。
对于request中的数据,可以在正式处理之前加
过滤器。
对于别的数据库,可以设一个专门的过滤类来转码。
如果是图形界面下的虚拟终端,设置(根据不同的 shell 修改不同的环境参数配置文件,如 bash 就修改 .bashrc 文件或 .bash_profile 文件)1
export LANG=zh_CN.UTF-8
如果是远程登录(比如使用 ssh 登录),则根据你的客户端的环境进行设置,一个可能的方案是:
1
export LANG=zh_CN.GB18030
locale 看看你的当前是什么语言显示然后
1
vi /etc/sysconfig/<a href="https://www.baidu.com/s?wd=i18n&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1YvPAfsPARvmHRdPHcdnjTL0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EPjnzPHD4nW0zPH6zPjbzrj6Y" target="_blank" class="baidu-highlight">i18n</a>
一般情况下linux服务器都是配置utf-8,不使用中文的。
用命令show
variables
like
"%char%"
看你的
character_set_system
这一项是什么字符集,然后在my.cnf中把default-character-set
=
这个字符集
就可以了,,,不过以前的
乱码
还是照样乱,以后的就可以显示了。。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)