[JAVA] IOException: Invalid byte 2 of 2-byte UTF-8 sequence(解决办法)

日志打印不全,后台只打印出出标题的异常信息:

先前的日志打印信息:log.debug(e.getMessage());

后面改成了日志打印信息:log.debug(e); log.debug(e.getStackTrace());

日志打印的重要性,不能单单只打印Message

 

问题原因查找,这个问题在微信支付的维权功能中出现,在网上找了原因之后,下面这个连接给出的最准确:

http://blog.csdn.net/linkyou/article/details/3975491

 

根本原因是以下代码:

public static InputStream String2Inputstream(String str) throws IOException {
        return new ByteArrayInputStream(str.getBytes("UTF-8"));
    }

在getBytes里加上UTF-8即可,根本原因是由于我们服务器上的编码方式是GBK的,这个时候这里取getBytes时会取得服务器上的编码方式,从而报错

 

总结:在任何地方涉及到字符串和二进制流转换的时候编码方式是一个重点需要关注的地方,所有编码方式都必须确定,而不是取自于服务器,对编码方式统一管理才是王道,同时,只能感叹,又被微信支付给坑到了,不过已经习惯了~

posted @ 2014-07-29 16:51  我是小菜鸟  阅读(1961)  评论(0编辑  收藏  举报