在jsp中常见的乱码解决办法无外乎是关于get和post两种方式的,但只有切实地在实践中使用时才会注意或者说注重到其余方式。例如,在http请求头中传送中文参数,出现乱码,如何解决? java
实际场景:使用Spring提供的RestTemplate向WebService发送put请求,使用HttpHeader类装载须要传递的参数(包括中文)。请求端系统使用的是utf-8编码,而服务端使用的是gbk编码,使用http监听工具查看所发出的http请求信息,发现header中的中文参数乱码。 json
尝试的方法: 服务器
1. 在服务端接收到参数时,utf-8转gbk,无效。
2. 在服务端接收到参数时,iso-8859-1转gbk,无效。
3. 在发送请求前将中文参数转码,utf-8转iso-8859-1,无效。代码以下: app
new String(remark.getBytes("UTF-8"), "ISO-8859-1")4. 在请求端,HttpHeader设定ContentType为“application/json;UTF-8",无效。代码以下:
headers.setContentType(Media.valueOf("application/json;UTF-8"));
写到这里,有人应该感受到这有点“病急乱投医”的感受了,没有头绪地在试着各类方式。是的,起初我以为是请求header中采用了ISO-8859-1的编码,但尝试后很显然不是;后来我觉着是不是RestTemplate中采用的HttpMessageConverter方式所决定的,但没能找到很好的证实方式,查资料说的是StringHttpMessageConverter默认采用的是ISO-8859-1编码,可我以为我指定了ContentType为application/json,RestTemplate不该该去调用StringHttpMessageConverter啊,其中的原理还有待深究。我的感受这种状况出问题的可能性最大。 jsp
最后,在网上看到一篇文章后,看了一种建议方式,而且是可行的,就是使用URLEncode,将中文参数在传参前进行encode。这里以GBK编码是为了在服务器端接收参数后无需再转码了,以下: 工具
list.add(URLEncode.encode(name, "GBK"));
URLEncode方式能够解决这种特定场景的中文乱码问题,相信理解其原理后还能够运用到更多的场景。目前我在网上看到的,关于用URLEncode处理中文乱码最多的场景就是文件下载时中文文件名乱码。 post
关于Java中文乱码的原理及解决办法能够参看一下下面的连接,颇有用。 编码
http://www.ibm.com/developerworks/cn/java/j-lo-chinesecoding/ spa