成都网站建设设计

将想法与焦点和您一起共享

PHP微信支付服务商开发如何配置

这篇文章给大家分享的是有关PHP微信支付服务商开发如何配置的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。

渌口网站建设公司创新互联公司,渌口网站设计制作,有大型网站制作公司丰富经验。已为渌口近千家提供企业网站建设服务。企业网站搭建\外贸网站制作要多少钱,请找那个售后服务好的渌口做网站的公司定做!

项目背景

不是什么大项目,使用微信服务商来管理多个子商户,并使用服务商的接口替子商户下单,服务商后台才能接收到回调

使用场景是web扫码支付

准备

域名应该要在服务商所归属的公众号内“网页授权域名”设置好(不知此操作是否需要?)

在支付服务商后台设置好回调地址(子商户应该是不用设置)

项目使用apache+php为后台服务,下载官方支付php demo(native)

我们直接先按照demo的目录结构来玩,直接把解压的example和lib,2个目录都到服务器根目录

在example目录下,创建cert目录,进服务商后台-账户中心-api安全,下载证书,放到这个目录内

在example目录下,创建logs目录,用于微信支付log类写日志文件

由于微信支付相关都要使用https,所以查看访问日志在apache目录下的logs目录,ssl_request.txt文件,最下面,可以看到回调地址是否被请求

注意

官方demo有2个方式的扫码支付,第一种方式已经不提供,都使用第二种

官方的demo,会有不能显示二维码的bug,例子页面是native.php

打印print_r($result);  这个,会显示错误,主要是关于于curl的错误,自行百度解决

配置

在WxPay.Config.Interface.php中的接口对象中增加一个公共方法public abstract function GetSubMchId(); //获取子商户id在WxPay.Config.php内中,配置需要的参数,自行百度,并且增加一个方法public function GetSubMchId(){   return '8888888888'; //返回子商户号 by vbyzc   }在lib/WxPay.Api.php 内,在统一下单方法unifiedOrder中,下面的参数那段位置,增加$inputObj->SetSub_mch_id($config->GetSubMchId());//子商户号 by vbyzc在各个需要查询订单的的地方回调,付款页面实时检测订单支付状态的请求页面,都要使用此方法来设置子商户id:
$input->SetSub_mch_id($config->GetSubMchId());注意,有的地方可能没有$config对象,请引入WxPay.Config.php ,并初始化:$config = new WxPayConfig();

部分代码

扫码页面:native.php

SetBody("test_body");
$input->SetAttach("test_Attach");//成功支付的回调里会返回这个
$input->SetOut_trade_no($out_trade_no);//自定义订单号
$input->SetTotal_fee("1"); // 金额
$input->SetTime_start(date("YmdHis"));
// $input->SetTime_expire(date("YmdHis", time() + 500));
$input->SetGoods_tag("test_goodsTag");
$input->SetNotify_url("https://service.ktfqs.com/example/wx_pay_callback.php");
$input->SetTrade_type("NATIVE");
$input->SetProduct_id("123456789"); //此id为二维码中包含的商品ID,商户自行定义。

$result = $notify->GetPayUrl($input);
$url2 = $result["code_url"];

echo "
这是返回:$url2
"; print_r($result); ?> 扫码支付
扫描支付模式二

订单编号
模式二扫码支付
支付提示:WAITING...

查询并返回订单状态页面:orderqueryajax.php

SetOut_trade_no($out_trade_no);
    $input->SetSub_mch_id($config->GetSubMchId());//子商户号 by vbyzc
    $result = WxPayApi::orderQuery($config, $input);
    if ($result['return_code'] == 'SUCCESS' && $result['result_code'] == 'SUCCESS'){//返回查询结果
        echo $result['trade_state'];
    }else{
        echo "FAIL";
    }
}
?>

回调页:notify.php

SetTransaction_id($transaction_id);
        $input->SetSub_mch_id($config->GetSubMchId()); //设置子商户号  by vbyzc
        $result = WxPayApi::orderQuery($config, $input);
        Log::DEBUG("query:" . json_encode($result));
        if(array_key_exists("return_code", $result)
            && array_key_exists("result_code", $result)
            && $result["return_code"] == "SUCCESS"
            && $result["result_code"] == "SUCCESS")
        {
            return true;
        }
        return false;
    }

    /**
    *
    * 回包前的回调方法
    * 业务可以继承该方法,打印日志方便定位
    * @param string $xmlData 返回的xml参数
    *
    **/
    public function LogAfterProcess($xmlData)
    {
        Log::DEBUG("call back, return xml:" . $xmlData);
        return;
    }
    
    //重写回调处理函数
    /**
     * @param WxPayNotifyResults $data 回调解释出的参数
     * @param WxPayConfigInterface $config
     * @param string $msg 如果回调处理失败,可以将错误信息输出到该方法
     * @return true回调出来完成不需要继续回调,false回调处理未完成需要继续回调
     */
    public function NotifyProcess($objData, $config, &$msg)
    {
        $data = $objData->GetValues();
        //TODO 1、进行参数校验
        if(!array_key_exists("return_code", $data) 
            ||(array_key_exists("return_code", $data) && $data['return_code'] != "SUCCESS")) {
            //TODO失败,不是支付成功的通知
            //如果有需要可以做失败时候的一些清理处理,并且做一些监控
            $msg = "异常异常";
            return false;
        }
        if(!array_key_exists("transaction_id", $data)){
            $msg = "输入参数不正确";
            return false;
        }

        //TODO 2、进行签名验证
        try {
            $checkResult = $objData->CheckSign($config);
            if($checkResult == false){
                //签名错误
                Log::ERROR("签名错误...");
                return false;
            }
        } catch(Exception $e) {
            Log::ERROR(json_encode($e));
        }

        //TODO 3、处理业务逻辑
        Log::DEBUG("call back JSON:" . json_encode($data));
        $notfiyOutput = array();
        /* 返回的格式 
        {
            "appid": "wxa664cef2fee1b641", //调用接口提交的公众账号ID
            "attach": "test",//附加数据,在查询API和支付通知中原样返回,该字段主要用于商户携带订单的自定义数据 (使用SetAttach设置的)
            "bank_type": "LQT",//不知什么鬼东西
            "cash_fee": "1",// 金额
            "fee_type": "CNY",//货币类型
            "is_subscribe": "N",//不知什么鬼东西
            "mch_id": "154133502151",// 商户号(服务商)
            "nonce_str": "jw0bvddz275qyvxnpdfoaam55h4dw6uk",//微信返回的随机字符串
            "openid": "opnVE5pDPx2hWAoLLxyQW5KQt8GA",// 用户openid(应该是对于绑定的公从号)
            "out_trade_no": "vbyzc_for_jstx20190701010509",// 发起订单时自定义订单号
            "result_code": "SUCCESS",// 业务结果
            "return_code": "SUCCESS",// 此字段是通信标识,非交易标识,交易是否成功需要查看result_code来判断
            "sign": "80E46C6CC50C25E6B5099AE4E03DA3C6FEFD5B172A99B03A56FAC4A9E11EC8F3",//
            "sub_mch_id": "154172463171",// 子商户id
            "time_end": "20190701090530",// 交易结束时间??
            "total_fee": "1",// 总金额
            "trade_type": "NATIVE",// 支付方式
            "transaction_id": "4200000301201907011310094985" // 微信支付单号
        }
        */
        //查询订单,判断订单真实性
        if(!$this->Queryorder($data["transaction_id"])){
            $msg = "订单查询失败";
            Log::DEBUG("vbyzc run to here : order querySelect faild!!!!!" );
            return false;
        }
        // 根据微信官方原代码的业务流程,应该是如下:
        // 支会成功后微信会不断请求回调,在上面的代码 应该是包函了回调回应的代码,
        // 如果成功回应,微信支付应该就停止请求回调,才能执行下面的代码 
        Log::DEBUG("vbyzc run to here :<<<<<<<<<<<<<>>>>>>>>>" );
        return true;
    }
}

$config = new WxPayConfig();
Log::DEBUG("begin notify");
$notify = new PayNotifyCallBack();
$notify->Handle($config, false);


?>

感谢各位的阅读!关于PHP微信支付服务商开发如何配置就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!


本文名称:PHP微信支付服务商开发如何配置
文章位置:http://chengdu.cdxwcx.cn/article/gjepse.html