微信提交预订单**请求**XML报文:
<xml>
<appid><![CDATA[wx45485fdfd5fd5fdfd]]></appid>
<mch_id><![CDATA[1687896659]]></mch_id>
<nonce_str><![CDATA[0XMLHISMJSJUQV7ZA6KD5GBQC5VCOVKU]]></nonce_str>
<sign><![CDATA[86E72FDB4A8608DD4EE5FA775FCA2EF4]]></sign>
<body><![CDATA[测试支付信息订单]]></body>
<out_trade_no><![CDATA[20220331164933testOrder]]></out_trade_no>
<total_fee><![CDATA[1000]]></total_fee>
<spbill_create_ip><![CDATA[52.10.153.25]]></spbill_create_ip>
<notify_url><![CDATA[https://www.aaa.com/wechat/pay_notify.jhtml]]></notify_url>
<trade_type><![CDATA[NATIVE]]></trade_type>
</xml>
微信提交预订单**返回**XML报文:
<xml>
<return_code><![CDATA[FAIL]]></return_code>
<return_msg><![CDATA[签名错误,请检查后再试]]></return_msg>
</xml>
调用预支付订单,一直提示签名错误。微信支付的证书, api_key 已经设置完毕。然后,在微信的官方文档里,测试接口,没问题,但是在代码里就一直提示 签名错误。下图是官方文档调试的截图:
没任何问题。
解决历程:
1. API密钥错误(被别人改动或者记错了)
在商户平台的账户信息中更改API密钥(账户设置-安全设置-API安全), 15分钟后生效;(未解决)
2. 编码问题,确保所有的都是utf-8的. 如果有中文, 可以先把中文改成英文重新签名,看是否签名错误,如果英文不会错中文才会错,基本肯定是编码问题(未解决)
3. 消息中字段大小写和文档中完全一致(未解决)
以上方法全没解决问题,然后断定不是自己的代码问题。果断查微信支付官网 配置问题。
然后发现了惊人的一段提示:
api_key 居然必须设置为32个字符,但是,这么重要的信息,居然没有任何特殊标注。最最恶心的是,在下面的设置页面,在输入api_key后,居然没有长度等校验,随便输入啥都行。然后数了一下自己的开始设置的key长度,果然不是32,而是34个字符。这绝对是微信的天大BUG。总结一句就是:设置密钥的地方不校验长度,但是代码调用接口的时候,就会校验。而且提示的错误是签名失败,不提示具体错误。耽误一整天,实在无力吐槽!!!记录下,警示后来兄弟!!