* 本例程对应的响应服务为native_call.php; * 需要两者配合使用。 * */ include_once "./log_.php"; include_once "../WxPayPubHelper/WxPayPubHelper.php"; //以log文件形式记录回调信息,用于调试 $log_ = new Log_(); $log_name = "./native_call.log"; //使用native通知接口 $nativeCall = new NativeCall_pub(); //接收微信请求 $xml = $GLOBALS['HTTP_RAW_POST_DATA']; $log_->log_result($log_name, "【接收到的native通知】:\n" . $xml . "\n"); $nativeCall->saveData($xml); if ($nativeCall->checkSign() == FALSE) { $nativeCall->setReturnParameter("return_code", "FAIL"); //返回状态码 $nativeCall->setReturnParameter("return_msg", "签名失败"); //返回信息 } else { //提取product_id $product_id = $nativeCall->getProductId(); //使用统一支付接口 $unifiedOrder = new UnifiedOrder_pub(); //根据不同的$product_id设定对应的下单参数,此处只举例一种 switch ($product_id) { case WxPayConf_pub::APPID . "static": //与native_call_qrcode.php中的静态链接二维码对应 //设置统一支付接口参数 //设置必填参数
public function todoPost() { //全局引入微信支付类 Vendor('Wxpay.WxPayPubHelper.WxPayPubHelper'); //以log文件形式记录回调信息,用于调试 $log_name = __ROOT__ . "/Public/Weixin/native_call.log"; //使用native通知接口 $nativeCall = new \NativeCall_pub(); //接收微信请求 $xml = $GLOBALS['HTTP_RAW_POST_DATA']; log_result($log_name, "【接收到的native通知】:\n" . $xml . "\n"); $nativeCall->saveData($xml); if ($nativeCall->checkSign() == FALSE) { $nativeCall->setReturnParameter("return_code", "FAIL"); //返回状态码 $nativeCall->setReturnParameter("return_msg", "签名失败"); //返回信息 } else { //提取product_id $product_id = $nativeCall->getProductId(); //使用统一支付接口 $unifiedOrder = new \UnifiedOrder_pub(); //根据不同的$product_id设定对应的下单参数,此处只举例一种 switch ($product_id) { case \WxPayConf_pub::APPID . "static": //与native_call_qrcode.php中的静态链接二维码对应 //设置统一支付接口参数 //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //spbill_create_ip已填,商户无需重复填写 //sign已填,商户无需重复填写 $unifiedOrder->setParameter("body", "贡献一分钱"); //商品描述 //自定义订单号,此处仅作举例 $timeStamp = time(); $out_trade_no = \WxPayConf_pub::APPID . $timeStamp; $unifiedOrder->setParameter("out_trade_no", $out_trade_no); //商户订单号 $unifiedOrder->setParameter("product_id","$product_id");//商品ID $unifiedOrder->setParameter("total_fee", "1"); //总金额 $unifiedOrder->setParameter("notify_url", \WxPayConf_pub::NOTIFY_URL); //通知地址 $unifiedOrder->setParameter("trade_type", "NATIVE"); //交易类型 $unifiedOrder->setParameter("product_id", $product_id); //用户标识 //非必填参数,商户可根据实际情况选填 //$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");//用户标识 //获取prepay_id $prepay_id = $unifiedOrder->getPrepayId(); //设置返回码 //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //sign已填,商户无需重复填写 $nativeCall->setReturnParameter("return_code", "SUCCESS"); //返回状态码 $nativeCall->setReturnParameter("result_code", "SUCCESS"); //业务结果 $nativeCall->setReturnParameter("prepay_id", $prepay_id); //预支付ID break; default: //设置返回码 //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //sign已填,商户无需重复填写 $nativeCall->setReturnParameter("return_code", "SUCCESS"); //返回状态码 $nativeCall->setReturnParameter("result_code", "FAIL"); //业务结果 $nativeCall->setReturnParameter("err_code_des", "此商品无效"); //业务结果 break; } } //将结果返回微信 $returnXml = $nativeCall->returnXml(); log_result($log_name, "【返回微信的native响应】:\n" . $returnXml . "\n"); echo $returnXml; }
/** * 回调内容 * $dataArr 提交参数内容 */ function CallbackInterface($dataArr = array()) { //使用native通知接口 $nativeCall = new NativeCall_pub(); if ($nativeCall->checkSign() == FALSE) { $nativeCall->setReturnParameter("return_code", "FAIL"); //返回状态码 $nativeCall->setReturnParameter("return_msg", "签名失败"); //返回信息 } else { //提取product_id $product_id = $nativeCall->getProductId(); //使用统一支付接口 $unifiedOrder = new UnifiedOrder_pub(); //根据不同的$product_id设定对应的下单参数,此处只举例一种 switch ($product_id) { case WxPayConf_pub::APPID . "static": //与native_call_qrcode.php中的静态链接二维码对应 $unifiedOrder->setParameter("body", $dataArr['body']); //商品描述 //自定义订单号,此处仅作举例 $unifiedOrder->setParameter("out_trade_no", $dataArr['out_trade_no']); //商户订单号 $unifiedOrder->setParameter("product_id","$product_id");//商品ID $unifiedOrder->setParameter("total_fee", $dataArr['total_fee']); //总金额 $unifiedOrder->setParameter("notify_url", WxPayConf_pub::NOTIFY_URL); //通知地址 $unifiedOrder->setParameter("trade_type", "NATIVE"); //交易类型 $unifiedOrder->setParameter("product_id", "{$product_id}"); //用户标识 //获取prepay_id $prepay_id = $unifiedOrder->getPrepayId(); $nativeCall->setReturnParameter("return_code", "SUCCESS"); //返回状态码 $nativeCall->setReturnParameter("result_code", "SUCCESS"); //业务结果 $nativeCall->setReturnParameter("prepay_id", "{$prepay_id}"); //预支付ID break; default: $nativeCall->setReturnParameter("return_code", "SUCCESS"); //返回状态码 $nativeCall->setReturnParameter("result_code", "FAIL"); //业务结果 $nativeCall->setReturnParameter("err_code_des", "此商品无效"); //业务结果 break; } } }
public function notify($payid) { //以log文件形式记录回调信息,用于调试 $log_ = new \Log_(); $time = date('Ymd', time()); $log_name = './logs/pay/' . $time . "native_call.log"; //使用native通知接口 $nativeCall = new \NativeCall_pub(); //接收微信请求 $xml = $GLOBALS['HTTP_RAW_POST_DATA']; $log_->log_result($log_name, "【接收到的native通知】:\n" . $xml . "\n"); $nativeCall->saveData($xml); if ($nativeCall->checkSign() == FALSE) { $nativeCall->setReturnParameter("return_code", "FAIL"); //返回状态码 $nativeCall->setReturnParameter("return_msg", "签名失败"); //返回信息 } else { //提取product_id $product_id = $nativeCall->getProductId(); //使用统一支付接口 $unifiedOrder = new \UnifiedOrder_pub(); //根据不同的$product_id设定对应的下单参数,此处只举例一种 switch ($product_id) { case WxPayConf_pub::APPID . "static": //与native_call_qrcode.php中的静态链接二维码对应 $unifiedOrder->setParameter("body", "贡献一分钱"); //商品描述 //自定义订单号,此处仅作举例 $timeStamp = time(); $out_trade_no = WxPayConf_pub::APPID . "{$timeStamp}"; $unifiedOrder->setParameter("out_trade_no", "{$out_trade_no}"); //商户订单号 $unifiedOrder->setParameter("product_id","$product_id");//商品ID $unifiedOrder->setParameter("total_fee", "1"); //总金额 $unifiedOrder->setParameter("notify_url", WxPayConf_pub::NOTIFY_URL); //通知地址 $unifiedOrder->setParameter("trade_type", "NATIVE"); //交易类型 $unifiedOrder->setParameter("product_id", "{$product_id}"); //用户标识 $unifiedOrder->setParameter("attach", "{$payid}"); //附加数据 订单ID //获取prepay_id $prepay_id = $unifiedOrder->getPrepayId(); $nativeCall->setReturnParameter("return_code", "SUCCESS"); //返回状态码 $nativeCall->setReturnParameter("result_code", "SUCCESS"); //业务结果 $nativeCall->setReturnParameter("prepay_id", "{$prepay_id}"); //预支付ID break; default: //设置返回码 //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //sign已填,商户无需重复填写 $nativeCall->setReturnParameter("return_code", "SUCCESS"); //返回状态码 $nativeCall->setReturnParameter("result_code", "FAIL"); //业务结果 $nativeCall->setReturnParameter("err_code_des", "此商品无效"); //业务结果 break; } } //将结果返回微信 $returnXml = $nativeCall->returnXml(); $log_->log_result($log_name, "【返回微信的native响应】:\n" . $returnXml . "\n"); exit($returnXml); //交易完成 }