花了两天时间,走出这个坑。
庆幸是这样的:我们的代码,在另一台机器上是正常的,但在我的机器上结果是不对的,;有两个功能点,一个是微信支付中签名的md5结果不对,一个是pdf生成的中文出不
来。
异常是这样的:
com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException: 2 字节的 UTF-8 序列的字节 2 无效。
经过各种尝试,最后认为问题一定在tomcat里面,然后比对两台电脑的tomcat,果然发现,tomcat的web.xml里面,一个是iso-8859-1,一个是utf8。编码是iso的那台电脑程序正常跑,编码是utf-8的,就出错。
搜索下,说是tomcat默认编码是ISO-8895-1。这样web应用运行的时候,MD5里面会把中文用iso编码处理,所以md5的结果就不对,微信的demo里是这样的:
resultString = byteArrayToHexString(md.digest(resultString.getBytes()));
getBytes要加参数,getBytes("utf-8");这样就好了。
pdf的生成中,也有使用getBytes,是同一个问题。
转载请注明原文地址: https://ju.6miu.com/read-50074.html