温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

使用ThinkPHP框架怎么实现一个微信支付接口

发布时间:2021-04-13 16:40:50 来源:亿速云 阅读:185 作者:Leah 栏目:开发技术

今天就跟大家聊聊有关使用ThinkPHP框架怎么实现一个微信支付接口,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

开发步骤

一、进入公众号平台,先设置几个参数,包括绑定域名、设置回调地址等等。

1、在设置 -> 公众号设置 -> 功能设置 -> 设置JS接口安全域名

 使用ThinkPHP框架怎么实现一个微信支付接口

2、在微信支付 -> 开发配置 -> 配置你的js支付接口,回调地址等等,正式目录和测试目录都可以写上,测试目录需要把个人微信号先添加到白名单才能使用(提醒:用TP框架的小伙伴们在填写支付授权目录时可以这样填写:域名/index.php/控制器/,经测试是可以通过的,微信一样能检测到,之前看到网上有人说这样不行,可能是现在升级了吧,呵呵,还有一个就是域名一定要是已经备过案的才行,如果是在本地进行测试的小伙伴们可以使用花生壳,我不是在打广告,个人觉得还是挺好用的)

 使用ThinkPHP框架怎么实现一个微信支付接口

3、在开发者中心把“网页授权获取用户基本信息”的域名写上自己的域名,微信登陆时需要用到的;

 使用ThinkPHP框架怎么实现一个微信支付接口

二、到上面一大步设置完成后就可以开始我们的开发工作了;

1、用TP的小伙伴们可以用下面的包放到tp的扩展里,也可以自行到官网下载sdk包,具体目录:ThinkPHP\Library\Vendor\,其它就可以不用管啦;

2、打开包里的WxPayPubConfig.php文件,填写上你的微信支付的接口信息就好啦;

三、上面二大步都是配置,这一步就是写支付类了,其实也没什么的,复制粘贴就好了;

1、新建Wxpay控制器,当然你也可以自己命名,访问的名称要跟你在微信上配置的授权目录一样就好了;点击这里下载Wxpay

2、代码的地方就不多说了,下面直接上代码;

<?php
namespace Home\Controller;
use Think\Controller;
//微信支付类
class WxpayController extends Controller {
  //获取access_token过程中的跳转uri,通过跳转将code传入jsapi支付页面
  public function js_api_call() {
    $order_sn = I('get.order_sn', '');
    if (empty($order_sn)) {
      header('location:'.__ROOT__.'/');
    }
    vendor('Weixinpay.WxPayPubHelper');
    //使用jsapi接口
    $jsApi = new \JsApi_pub();
    //=========步骤1:网页授权获取用户openid============
    //通过code获得openid
    if (!isset($_GET['code'])){
      //触发微信返回code码
      $url = $jsApi->createOauthUrlForCode('域名/Wxpay/js_api_call?order_sn='.$order_sn);
      //$url = $jsApi->createOauthUrlForCode(\WxPayConf_pub::JS_API_CALL_URL);
      Header("Location: $url");
    }else{
      //获取code码,以获取openid
      $code = $_GET['code'];
      $jsApi->setCode($code);
      $openid = $jsApi->getOpenId();
    }
    $res = array(
      'order_sn' => '20150109113322',
      'order_amount' => 255
    );
    //=========步骤2:使用统一支付接口,获取prepay_id============
    //使用统一支付接口
    $unifiedOrder = new \UnifiedOrder_pub();
    //设置统一支付接口参数
    //设置必填参数
    //appid已填,商户无需重复填写
    //mch_id已填,商户无需重复填写
    //noncestr已填,商户无需重复填写
    //spbill_create_ip已填,商户无需重复填写
    //sign已填,商户无需重复填写
    $total_fee = $res['order_amount']*100;
    //$total_fee = 1;
    $body = "订单支付{$res['order_sn']}";
    $unifiedOrder->setParameter("openid", "$openid");//用户标识
    $unifiedOrder->setParameter("body", $body);//商品描述
    //自定义订单号,此处仅作举例
    $out_trade_no = $res['order_sn'];
    $unifiedOrder->setParameter("out_trade_no", $out_trade_no);//商户订单号
    $unifiedOrder->setParameter("total_fee", $total_fee);//总金额
    //$unifiedOrder->setParameter("attach", "order_sn={$res['order_sn']}");//附加数据
    $unifiedOrder->setParameter("notify_url", \WxPayConf_pub::NOTIFY_URL);//通知地址
    $unifiedOrder->setParameter("trade_type", "JSAPI");//交易类型
    //非必填参数,商户可根据实际情况选填
    //$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商户号
    //$unifiedOrder->setParameter("device_info","XXXX");//设备号
    //$unifiedOrder->setParameter("attach","XXXX");//附加数据
    //$unifiedOrder->setParameter("time_start","XXXX");//交易起始时间
    //$unifiedOrder->setParameter("time_expire","XXXX");//交易结束时间
    //$unifiedOrder->setParameter("goods_tag","XXXX");//商品标记
    //$unifiedOrder->setParameter("openid","XXXX");//用户标识
    //$unifiedOrder->setParameter("product_id","XXXX");//商品ID
    $prepay_id = $unifiedOrder->getPrepayId();
    //=========步骤3:使用jsapi调起支付============
    $jsApi->setPrepayId($prepay_id);
    $jsApiParameters = $jsApi->getParameters();
    $wxconf = json_decode($jsApiParameters, true);
    if ($wxconf['package'] == 'prepay_id=') {
      $this->error('当前订单存在异常,不能使用支付');
    }
    $this->assign('res', $res);
    $this->assign('jsApiParameters', $jsApiParameters);
    $this->display('jsapi');
  }
  //异步通知url,商户根据实际开发过程设定
  public function notify_url() {
    vendor('Weixinpay.WxPayPubHelper');
    //使用通用通知接口
    $notify = new \Notify_pub();
    //存储微信的回调
    $xml = $GLOBALS['HTTP_RAW_POST_DATA'];
    $notify->saveData($xml);
    //验证签名,并回应微信。
    //对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
    //微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
    //尽可能提高通知的成功率,但微信不保证通知最终能成功。
    if($notify->checkSign() == FALSE){
      $notify->setReturnParameter("return_code", "FAIL");//返回状态码
      $notify->setReturnParameter("return_msg", "签名失败");//返回信息
    }else{
      $notify->setReturnParameter("return_code", "SUCCESS");//设置返回码
    }
    $returnXml = $notify->returnXml();
    //==商户根据实际情况设置相应的处理流程,此处仅作举例=======
    //以log文件形式记录回调信息
    //$log_name = "notify_url.log";//log文件路径
    //$this->log_result($log_name, "【接收到的notify通知】:\n".$xml."\n");
    $parameter = $notify->xmlToArray($xml);
    //$this->log_result($log_name, "【接收到的notify通知】:\n".$parameter."\n");
    if($notify->checkSign() == TRUE){
      if ($notify->data["return_code"] == "FAIL") {
        //此处应该更新一下订单状态,商户自行增删操作
        //$this->log_result($log_name, "【通信出错】:\n".$xml."\n");
        //更新订单数据【通信出错】设为无效订单
        echo 'error';
      }
      else if($notify->data["result_code"] == "FAIL"){
        //此处应该更新一下订单状态,商户自行增删操作
        //$this->log_result($log_name, "【业务出错】:\n".$xml."\n");
        //更新订单数据【通信出错】设为无效订单
        echo 'error';
      }
      else{
        //$this->log_result($log_name, "【支付成功】:\n".$xml."\n");
        //我这里用到一个process方法,成功返回数据后处理,返回地数据具体可以参考微信的文档
        if ($this->process($parameter)) {
          //处理成功后输出success,微信就不会再下发请求了
          echo 'success';
        }else {
          //没有处理成功,微信会间隔的发送请求
          echo 'error';
        }
      }
    }
  }
  //订单处理
  private function process($parameter) {
    //此处应该更新一下订单状态,商户自行增删操作
    /*
    * 返回的数据最少有以下几个
    * $parameter = array(
      'out_trade_no' => xxx,//商户订单号
      'total_fee' => XXXX,//支付金额
      'openid' => XXxxx,//付款的用户ID
    );
    */
    return true;
  }
}
?>

看完上述内容,你们对使用ThinkPHP框架怎么实现一个微信支付接口有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI