今天纪录一个小问题:
如题,在页面文本框或者得到的“中文值”乱码,然后去数据库查找返回 失败!
找了很多方法,发觉不适用。
最后发现解决方法就一句话。
解决方法:
(1)
在返回的action中,对str字符串做如下改动,就OK!
str = new String(str.getBytes("iso-8859-1"),"utf-8");
(2)
可以在Tomcat的配置文件(server.xml)中:添加指定编码集:
<Connector URIEncoding="UTF-8" port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<!-- A "Connector" using the shared thread pool-->
分析:
知其然,知其所以然:从浏览器提交的信息 是以字节提交的服务器,服务器解析,最后转化为对应的信息。
中间被解析成字节,当解析回去的时候,就会以服务器对应的编码解析。(Tomcat好像默认是ISO-8859-1编码)
所以必须 从新生成 自己想要的编码集字符,即声明为:UTF-8。也可以直接在tomcat里面配置。
(总的来的在tomcat里面配置比较好,可以省去许多代码,不好之处就是每部署到一个tomcat中都要去手动配置)
其默认编码和需求编码按照不同的“需求”和“容器”不同!
than's OK !