微信支付jsapi缺少参数 total_fee 错误分析与解决方法
<p>微信支付jsapi缺少参数 total_fee,其实很多参数错误都会报这个错,其实不一定是参数 total_fee,所以最好是单步或者在日志文件输出中间结果,毕竟服务器上没几个装开发软件的。</p><p>最近更换服务器之后,加上了nginx做代理并做了负载均衡后,微信支付第一次支付缺少参数 total_fee,再支付就可以,再点支付有报错缺少参数 total_fee,好奇怪,按理说是不应该报错或者要就一直报错,看了好一会代码,没问题,最后把统一下单的参数打印到后台,终于发现问题</p>
<p><img alt="" src="https://img.jbzj.com/file_images/article/201803/201832694735087.png?201822694827" /></p>
<p>统一下单中spbill_create_ip参数一会是127.0.0.1(ipv4),一会是0:0:0:0:0:0:0:1(ipv6)</p>
<p>当为ipv4是可以正常调用,为ipv6是就发生缺少参数 total_fee错误,其实后台报错是</p>
<div class="jb51code">
<pre class="brush:xhtml;">
<xml>
<return_code>
<!]>
</return_code>
<return_msg><!]></return_msg>
</xml>
</pre>
</div>
<p>从中可以发现</p>
<p><strong>1、微信支付不支持ipv6;</strong></p>
<p><strong>2、spbill_create_ip参数虽然要求为非空,但是微信只是校验了非空,没有根本要求要实际的用户端实际ip,(127.0.0.1都能发起支付);</strong></p>
<p><strong>3、同时,我们也发现为什么ipv4情况下会一直是127.0.0.1,因为用了nginx做了代理,所以request.getRemoteAddr获取的IP永远是本机地址。</strong></p>
<p>确定问题所在,下面解决问题,把获取IP地址的方法换一下</p>
<p>原来是</p>
<div class="jb51code">
<pre class="brush:xhtml;">
parameterMap.put("spbill_create_ip", request.getRemoteAddr());</pre>
</div>
<p>更换成</p>
<div class="jb51code">
<pre class="brush:java;">
public static String getIpAddr(HttpServletRequest request) {
String ip = request.getHeader("x-forwarded-for");
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("WL-Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getRemoteAddr();
}
return ip;
}
</pre>
</div>
<p>这样获取的IP是ipv4是也是客户的真实ip。</p>
<p>有时报这个错误并不一定是IP的问题,前端报错都是微信支付jsapi缺少参数 total_fee,所以最好的方法还是把中间结果打印出来或者断点测试一下</p>
<div class="art_xg">
<b>您可能感兴趣的文章:</b><ul><li>ThinkPHP框架整合微信支付之JSAPI模式图文详解</li><li>ThinkPHP实现微信支付(jsapi支付)流程教程详解</li><li>PHP实现微信支付(jsapi支付)和退款(无需集成支付SDK)流程教程详解</li><li>PHP实现微信支付(jsapi支付)流程步骤详解</li><li>微信支付java版本之JSAPI支付+发送模板消息</li><li>Java通过JsApi方式实现微信支付</li><li>微信支付之JSAPI公众号支付详解</li></ul>
</div>
</div>
<!--endmain-->
頁:
[1]