java https请求 中文乱码问题

java https请求 中文乱码问题,第1张

尝试的方法:

1. 在服务端接收到参数时,utf-8转gbk,无效。

2. 在服务端接收到参数时,iso-8859-1转gbk,无效。

3. 在发送请求前将中文参数转码,utf-8转iso-8859-1,无效。代码如下:

new String(remark.getBytes(“UTF-8”), “ISO-8859-1”)

4. 在请求端,HttpHeader设定ContentType为“application/jsonUTF-8”,无效。代码如下:

headers.setContentType(Media.valueOf(“application/jsonUTF-8”));

写到这里,有人应该感觉到这有点“病急乱投医”的感觉了,没有头绪地在试着各种方式。是的,起初我觉得是请求header中采用了ISO-8859-1的编码,但尝试后很显然不是;后来我觉着是否是RestTemplate中采用的HttpMessageConverter方式所决定的,但没能找到很好的证明方式,查资料说的是StringHttpMessageConverter默认采用的是ISO-8859-1编码,可我觉得我指定了ContentType为application/json,RestTemplate不应该去调用StringHttpMessageConverter啊,其中的原理还有待深究。个人感觉这种情况出问题的可能性最大。

最后,在网上看到一篇文章后,看了一种建议方式,并且是可行的,就是使用URLEncode,将中文参数在传参前进行encode.这里以GBK编码是为了在服务器端接收参数后无需再转码了,如下:

list.add(URLEncode.encode(name, “GBK”));

URLEncode方式可以解决这种特定场景的中文乱码问题,相信理解其原理后还可以运用到更多的场景。目前我在网上看到的,关于用URLEncode处理中文乱码最多的场景就是文件下载时中文文件名乱码。

以上的2个方法最好都要用上 过滤器只能解决POST请求 ,要处理GET请求就要用

bytes = string.getBytes("iso-8859-1") 得到原始的字节串,再用 string = new String(bytes, "GB2312") 重新得到正确的字符串 。

这个方法,所以最好2个都要写,这样不管是POST还是GET请求就都能解决了。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/bake/11821751.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存