当使用tomcat部署servlet连接时,总是出现各种原因的中文乱码问题。有的是因为mysql的默认字符集的问题,有的是客户端的字符配置问题。
现在对于这两种问题进行配置,来解决乱码。
服务器端(mySQL)的字符集配置:
show charset;//显示支持的所有字符集,大约有40多种;
SHOW VARIABLES LIKE 'character_set_%';//查看SQL使用的编码格式;
set character_set_client = utf8;//将SQL的一个属性改为utf8编码;
ps:注释符号好像错了,不过能明白就好。
将所有的SQL中使用的非utf8全改为utf8编码,虽然做的有点过头了,但是保险,以防未知的万一。
然后就是在java文件中更改url为:
jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8
这个只是例子,内容是:localhost,库为test,无密码,重点是后面的,将字符集设置为utf8!
这样改完后,一切都好起来了,天空瞬间万里无云。
还有,需要事先将request和response的编码设定为utf-8;这样就真的大一统了。
虽然有时对于request的设定并没卵,但是,我就喜欢这样,你管得着么。