当前位置:   article > 正文

微信支付遇到的小问题_微信云支付 functionname没有打印日志

微信云支付 functionname没有打印日志
  1. 相信第一次开发微信支付的童鞋都是从下载修改微信提供的例子开始,而微信官方提供的“微信公众号支付接口文档V3.3.7”中的PHP版本例子,一开始就跟大家开了个玩笑(这里强烈鄙视一下微信开发团队!!)

    1. Notice: Use of undefined constant CURLOP_TIMEOUT - assumed 'CURLOP_TIMEOUT' in /wx_pay_test/WxPayPubHelper/WxPayPubHelper.php on line 155
    2. Warning: curl_setopt() expects parameter 2 to be long, string given in wx_pay_test/WxPayPubHelper/WxPayPubHelper.php on line 155

    正确的写法为: curl_setopt($ch, CURLOPT_TIMEOUT, $second);


  2. “access_control:not_allow” 可能出现的问题是:

    1)如果是未通过审核的微信服务号,确认是否已经把测试用的微信普通用户号加入到“测试白名单(微信支付->开发配置->测试白名单)”

    2)负责发起支付的php程序所在的目录,是否已经设置被设置成为“支付授权目录”或“测试目录”,例如:需要把例子中的http://www.*****.com/WxPayController/ 设置为支付授权目录或测试目录


  3. “支付金额参数total_fee问题”,这个金额是提交给微信的扣款金额,单位是,所以假如扣款:12.98元, 提交的数据应该是 1298


  4. 别尝试使用AJAX 方式调用js_api_call.php,来进行微信支付。


  5. 公众号支付使用了无效的商户号”,导致这个错误出现的原因有很多,下面只能提供一个调试的方法,可根据自己的实际情况处理。由于微信支付测试比较困难,只有在微信内才可以测试。一些 xml格式的文件无法使用var_dump来输出,网上搜索找到一个生成log记录信息的方式:

    1. // 打印log
    2.     function  log_d($word
    3.     {
    4.         $log_name="./logd.log";//log文件路径
    5.         $fp fopen($log_name,"a");
    6.         flock($fp, LOCK_EX) ;
    7.         fwrite($fp,"执行日期:".strftime("%Y-%m-%d-%H:%M:%S",time())."\n".$word."\n\n");
    8.         flock($fp, LOCK_UN);
    9.         fclose($fp);
    10.     }

    在demo里面的 WxPayPubHelper.php 里面 用 $this->log_d(xxx);调用。


    普通的对象输出可使用:var_dump(××××);


  6. 支付成功后的 notify_url ,无法接受到数据问题:

    首先 notify_url 不能使用如 &a=1&b=2 格式 应使用如下 /a/1/b/2 Pathinfo模式 如果是Linux环境还需要对文件夹有 相应的权限 才能写入信息。

    开发者可以在 notify_url 中根据 支付返回的状态进行一些相应的操作 例如修改订单状态...发送模板消息 提醒用户交易成功等等。


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/624327
推荐阅读
相关标签
  

闽ICP备14008679号