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微信支付服务商开发如何配置
URL链接:http://myzitong.com/article/gjepse.html