前面已经跑通了微信支付的流程,接下来吧微信支付和微信企业付款接入到thinkphp中,版本是3.2

把微信支付类、企业付款类整合到一起放到第三方类库,这里我把微信支付帮助类和企业付款类放到同一个文件了:

把Payment整个文件夹放到\ThinkPHP\Library\Vendor文件夹下面,

python 控制企业微信 thinkphp 企业微信_thinkphp 微信支付 微信企业付款

打开WxPay.pub.config.php,配置四个参数即可,然后把微信提供的证书放到caccert文件夹;这样就完成了支付和企业付款的所有代码配置!

//=======【基本信息设置】=====================================
    //微信公众号身份的唯一标识。审核通过后,在微信发送的邮件中查看
    const APPID = '';
    //受理商ID,身份标识
    const MCHID = '';
    //商户支付密钥Key。审核通过后,在微信发送的邮件中查看
    const KEY = '';
    //JSAPI接口中获取openid,审核后在公众平台开启开发模式后可查看
    const APPSECRET = '';

在 Application/Home/Controller目录,建立WxPayController.class.php,下面是公众号支付和扫码支付模式2的方法

/*微信公众号支付*/
    public function jsapi($openid,$amount){
        Vendor('Payment.WxPay.WxPayPubHelper.WxPayPubHelper');
        //使用jsapi接口
        $jsApi = new \Vendor\Payment\WxPay\WxPayPubHelper\JsApi_pub();
        //=========步骤1:网页授权获取用户openid============
        //通过code获得openid

        //=========步骤2:使用统一支付接口,获取prepay_id============
        //使用统一支付接口
        $unifiedOrder = new \Vendor\Payment\WxPay\WxPayPubHelper\UnifiedOrder_pub();

        //设置统一支付接口参数
        //设置必填参数
        $unifiedOrder->setParameter("openid","$openid");//商品描述
        $unifiedOrder->setParameter("body","充值");//商品描述
        //自定义订单号,此处仅作举例
        $timeStamp = time();
        $out_trade_no =$timeStamp;
        $unifiedOrder->setParameter("out_trade_no","$out_trade_no");//商户订单号
        $unifiedOrder->setParameter("total_fee",$amount*100);//总金额
        $unifiedOrder->setParameter("notify_url",$this->notify_url);//通知地址
        $unifiedOrder->setParameter("trade_type","JSAPI");//交易类型
        $prepay_id = $unifiedOrder->getPrepayId();


        //=========步骤3:使用jsapi调起支付============
        $jsApi->setPrepayId($prepay_id);

        $jsApiParameters = $jsApi->getParameters();
        $data['jsApiParameters'] = $jsApiParameters;
        $data['out_trade_no'] = $out_trade_no;
        return $data;
    }

    //JSAPI支付通知
    public function notify(){
        //使用通用通知接口
        Vendor('Payment.WxPay.WxPayPubHelper.WxPayPubHelper');
        $notify = new \Vendor\Payment\WxPay\WxPayPubHelper\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();
        echo $returnXml;

        //==商户根据实际情况设置相应的处理流程,此处仅作举例=======

        //以log文件形式记录回调信息
        $log_name= dirname(__FILE__)."/../../../Public/Weixin/notify_url.log";//log文件路径
        $log_ = new \Vendor\Payment\WxPay\WxPayPubHelper\Log_();
        $log_->log_result($log_name,"【接收到的notify通知】:\n".$xml."\n");

        if($notify->checkSign() == TRUE)
        {
            if ($notify->data["return_code"] == "FAIL") {
                //此处应该更新一下订单状态,商户自行增删操作
                $log_->log_result($log_name,"【通信出错】:\n".$xml."\n");
            }
            elseif($notify->data["result_code"] == "FAIL"){
                //此处应该更新一下订单状态,商户自行增删操作
                $log_->log_result($log_name,"【业务出错】:\n".$xml."\n");
            }
            else{
                //此处应该更新一下订单状态,商户自行增删操作
                $log_->log_result($log_name,"【支付成功】:\n".$xml."\n");
                //商户自行增加处理流程,
                //例如:更新订单状态
                //例如:数据库操作
                //例如:推送支付完成信息

            }

        }
    }

    //微信扫码支付 模式2
    public function native_pays($amount){
        //全局引入微信支付类
        Vendor('Payment.WxPay.WxPayPubHelper.WxPayPubHelper');
        //使用统一支付接口
        $unifiedOrder = new \Vendor\Payment\WxPay\WxPayPubHelper\UnifiedOrder_pub();

        //设置统一支付接口参数
        //设置必填参数
        //appid已填,商户无需重复填写
        //mch_id已填,商户无需重复填写
        //noncestr已填,商户无需重复填写
        //spbill_create_ip已填,商户无需重复填写
        //sign已填,商户无需重复填写
        $unifiedOrder->setParameter("body","充值");//商品描述
        //自定义订单号,此处仅作举例
        $timeStamp = time();
        $out_trade_no = $timeStamp.$this->user_id;
        $unifiedOrder->setParameter("out_trade_no","$out_trade_no");//商户订单号
        $unifiedOrder->setParameter("total_fee",$amount*100);//总金额
        $unifiedOrder->setParameter("notify_url", $this->notify_url);//通知地址
        $unifiedOrder->setParameter("trade_type","NATIVE");//交易类型
        //非必填参数,商户可根据实际情况选填
        //$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

        //获取统一支付接口结果
        $unifiedOrderResult = $unifiedOrder->getResult();

        //商户根据实际情况设置相应的处理流程
//        if ($unifiedOrderResult["return_code"] == "FAIL")
//        {
//            //商户自行增加处理流程
//            echo "通信出错:".$unifiedOrderResult['return_msg']."<br>";
//        }
//        elseif($unifiedOrderResult["result_code"] == "FAIL")
//        {
//            //商户自行增加处理流程
//            echo "错误代码:".$unifiedOrderResult['err_code']."<br>";
//            echo "错误代码描述:".$unifiedOrderResult['err_code_des']."<br>";
//        }
        if($unifiedOrderResult["code_url"] != NULL)
        {
            //从统一支付接口获取到code_url
            $code_url = $unifiedOrderResult["code_url"];
            //商户自行增加处理流程
            //......
        }
        //$this->assign('out_trade_no',$out_trade_no);
        //$this->assign('code_url',$code_url);
        //$this->assign('unifiedOrderResult',$unifiedOrderResult);
        $data['out_trade_no'] = $out_trade_no;
        $data['result'] = $unifiedOrderResult;
        return $data;
//        $this->display("Home@WxPay:native_pays");//扫码模板
//        exit;
    }

然后在IndexController 写一个调用微信支付的方法

/*微信支付*/
    public function wxpay(){
        $openid = "ovOFkwccfw7PsERjKyhrZyDGm1-4";//"ovOFkwXd1PPolPDSH9ILyFMlRdF8";
        $amount = 1;
        $pay = A("Home/WxPay");
        $res = $pay->jsapi($openid,$amount);
        print_r($res['jsApiParameters']);
        $this->assign("jsApiParameters",$res['jsApiParameters']);
        $this->display("");
    }

这样就完成thinkphp接入微信支付了,手机访问:域名/index.php/Home/Index/wxpay ,测试截图:

python 控制企业微信 thinkphp 企业微信_微信支付_02

python 控制企业微信 thinkphp 企业微信_微信_03

 

在前面我们已经payment文件夹的ThinkPHP/Library/Vendor/Payment/WxPay/WxPayPubHelper/WxPayPubHelper.php 包含了 企业付款类

直接在IndexController 写一个调用企业付款的方法,看到吧,封装好后,调用就是这么简单

 

/*企业付款*/
    function merchpay(){
        header("Content-type: text/html; charset=utf-8");
        Vendor('Payment.WxPay.WxPayPubHelper.WxPayPubHelper');
        $obj = new \Vendor\Payment\WxPay\WxPayPubHelper\MerchPay();
        $openid = 'ovOFkwXd1PPolPDSH9ILyFMlRdF8';
        $trade_no = date('YmdHis').mt_rand(1000,9999);
        $res = $obj->pay($openid,$trade_no,1,'提现');
        print_r($res);
        return $res;
    }

手机打开测试截图:

python 控制企业微信 thinkphp 企业微信_微信支付_04

  

 这样就完成了thinkphp接入微信支付、微信企业付款。

新增了接入微信扫码支付和整理了接入教程,这样电脑也可以使用微信扫码支付了!

python 控制企业微信 thinkphp 企业微信_微信支付_05

python 控制企业微信 thinkphp 企业微信_支付接口_06