这篇文章给大家分享的是有关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://www.jxjierui.cn/article/gjepse.html


咨询
建站咨询
