今天遇到一个很“奇怪”的问题,使用URLConnection发送POST请求调用中台某个接口一直返回500错误。
那就开始排查问题吧。确认了请求参数的格式没有错误,标点符号都是对的,并且加了请求头参数connection.setRequestProperty("Accept-Charset", "UTF-8");
,再次调用还是返回500错误。
看了一眼我的请求参数,突然意识到是不是我传了中文的问题?
于是把中文全部换成英文,调用成功。
那问题来了,为什么有中文服务器就会返回500呢?我很确定传过去的JSON是对,并且System.out.println(parse)多次,期间一度怀疑自己的眼睛…
于是我联系到该服务器负责同事,要到了调用接口的具体返回错误,并打了断点看看我到底传了啥过去。
结果就看到,传过去的所有中文都成了一串乱码。。
既然JSON字符串在传过去前是正确的,那问题很显然就出现在这了:
DateOutputStream的writeBytes()方法,那点进去看看写了啥吧!
实际上就是for循环里writeBytes()中对字符串s的每个字符强制转换为低精度的byte类型(占1个字节),而char类型占2字节,char存入中文字符就精度丢失造成乱码了。
问题知道了,怎么解决?
那就好说了,先把字符串转成字节数组,抛弃writeBytes(),改用wrtie()。
再次调用接口,200,问题解决。
合理。