微信统一下单body参数中文报错问题

微信统一下单接口有一个body参数,是对商品的描述,这里一般需要用到中文,但是提交时却被返回下单失败。这个问题困扰了我很久,主要是被网上一些不负责任的给坑了。

这里来说一下这个问题的真正解决方式。

 

首先,当微信返回数据报错时要看清楚报错原因,因为body参数中文的问题导致的下单失败微信返回结果有两种,一种是微信告诉你body编码格式不是UTF-8,另一种是告诉你签名错误。这里一定要搞清楚,才能对症下药。

 

一.body编码格式不是UTF-8的错误

当微信返回给你的错误信息是这个的时候,说明你提交请求的编码格式不是UTF-8,微信端识别不了,所以返回给你这个错误信息,这个时候我们主要检查两个地方,一个是我们发起请求的http请求的工具的编码格式,在一个是我们tomcat服务器的编码格式。

1.网络传输的输出流改为UTF-8方式如下(具体各位用的什么输出流自己去查下如何设置编码格式就好了,我就不科普了)。

OutputStreamWriter outWriter = new OutputStreamWriter(conn.getOutputStream(), "UTF-8");

PrintWriter out = new PrintWriter(outWriter);
out.print(xml);
out.flush();
out.close();

2.把tomcat中server.xml文件中的URIEncoding改为 UTF-8 如下

 

ok,这两步完成,微信给你的报错就不再是编码格式不是UTF-8了,而是变成了签名错误。

二.返回签名错误

先说好了,这个签名错误发生的前提是,你的body传中文给你返回签名错误,如果你的body是英文你也是签名错误说明你的签名方法有问题,就先别继续往下看了

这里不得不说,查资料好多人都说把发的xml一转码就可以例如:

new_xml = new String(old_xml.getBytes(), "utf-8");//这是没用的!!!!!

在这里说一下,可能是我愚钝,反正这么做我是没解决问题。首先你的xml已经拼接生成好了,说明你的签名肯定也处理好了,当你进行转码时,你的签名sign已经是生成好了的了,这个时候你把汉字的码一转,你的sign是英文又不会变,但是你的body内容变了,在微信端获取到的body跟你自己生成签名时的body内容是不一样的,导致微信端生成的sign并不是你所生成的sign,问题当然解决不了。(不懂为什么好多人都在转这种解决方式,评论明明都在说解决不了)

 

为了保证微信获取到你的参数后生成的sign与你的一致,你要做的就是在生成sign之前就设置好这个body内容的编码格式。而不是生成了xml之后再对xml编码格式做修改。

String new_body=new String(old_body.getBytes(),"utf-8");

用new_body作为body参数的内容去参与sign的生成以及xml的拼接,微信就不会报错了。

你可能感兴趣的:(微信)