微信扫码支付
先在初始化中引入微信支付接口。 vendor('WxPayPubHelper.WxPayPubHelper'); 下面是当前视图对应的控制器(CartController.class.php) $unifiedOrder = new \UnifiedOrder_pub(); //设置统一支付接口参数 //设置必填参数 $unifiedOrder->setParameter("body","订单:{$orderno}");//商品描述 //$unifiedOrder->setParameter("body",$sysinfoTitle);//商品描述 //自定义订单号,此处仅作举例 //$timeStamp = time(); $timeStamp = $orderno; $out_trade_no = "$timeStamp"; $unifiedOrder->setParameter("out_trade_no","$out_trade_no");//商户订单号 $unifiedOrder->setParameter("total_fee",$cakelist['carttotal']*100);//总金额(*100到分单位) $unifiedOrder->setParameter("notify_url", '');//通知地址 $unifiedOrder->setParameter("trade_type","NATIVE");//交易类型 //获取统一支付接口结果 $unifiedOrderResult = $unifiedOrder->getResult(); //商户根据实际情况设置相应的处理流程 if ($unifiedOrderResult["return_code"] == "FAIL") { //商户自行增加处理流程 echo "通信出错:".$unifiedOrderResult['return_msg']." "; } elseif($unifiedOrderResult["result_code"] == "FAIL") { //商户自行增加处理流程 echo "错误代码:".$unifiedOrderResult['err_code']." "; echo "错误代码描述:".$unifiedOrderResult['err_code_des']." "; } elseif($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); 下面是主要逻辑操作。 public function notify() { //使用通用通知接口 $notify = new \Notify_pub(); //存储微信的回调 $xml = $GLOBALS['HTTP_RAW_POST_DATA']; $notify->saveData($xml); // var_dump($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_ = new Log_(); $log_name= __ROOT__."/Public/notify_url.log";//log文件路径 $this->log_result($log_name,"【接收到的notify通知】:\n".$xml."\n"); if($notify->checkSign() == TRUE) { if ($notify->data["return_code"] == "FAIL") { //此处应该更新一下订单状态,商户自行增删操作 log_result($log_name,"【通信出错】:\n".$xml."\n"); $this->error("1"); } elseif($notify->data["result_code"] == "FAIL"){ //此处应该更新一下订单状态,商户自行增删操作 log_result($log_name,"【业务出错】:\n".$xml."\n"); $this->error("失败2"); } else{ //此处应该更新一下订单状态,商户自行增删操作 log_result($log_name,"【支付成功】:\n".$xml."\n"); $this->success("支付成功!"); } //商户自行增加处理流程, //例如:更新订单状态 //例如:数据库操作 //例如:推送支付完成信息 } } //查询订单 public function orderQuery() { //退款的订单号 if (!isset($_POST["out_trade_no"])) { $out_trade_no = " "; }else{ $out_trade_no = $_POST["out_trade_no"]; //使用订单查询接口 $orderQuery = new \OrderQuery_pub(); //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //sign已填,商户无需重复填写 $orderQuery->setParameter("out_trade_no","$out_trade_no");//商户订单号 //非必填参数,商户可根据实际情况选填 //$orderQuery->setParameter("sub_mch_id","XXXX");//子商户号 //$orderQuery->setParameter("transaction_id","XXXX");//微信订单号 //获取订单查询结果 $orderQueryResult = $orderQuery->getResult(); //商户根据实际情况设置相应的处理流程,此处仅作举例 if ($orderQueryResult["return_code"] == "FAIL") { $this->error($out_trade_no); } elseif($orderQueryResult["result_code"] == "FAIL"){ //$this->ajaxReturn('','支付失败!',0); $this->error($out_trade_no); } else{ $i=$_SESSION['i']; $i--; $_SESSION['i'] = $i; //判断交易状态 switch ($orderQueryResult["trade_state"]) { case SUCCESS: /*成功后可以加入自己的逻辑操作*/ $count=M('cart_2_order')->where(array('orderno' =>$out_trade_no)) ->setField('orderstatus',1); if($count){ M('cart')->where('1=1')->delete(); $this->redirect('/center'); } $this->success("支付成功!"); break; case REFUND: //$this->error("超时关闭订单:".$i); break; case NOTPAY: //$this->error("超时关闭订单:".$i); // $this->ajaxReturn($orderQueryResult["trade_state"], "支付成功", 1); break; case CLOSED: //$this->error("超时关闭订单:".$i); break; case PAYERROR: $this->error("支付失败".$orderQueryResult["trade_state"]); break; default: $this->error("未知失败".$orderQueryResult["trade_state"]); break; } } } }
上一篇:Python几套常用开发工具对比
QQ客服
公众号
手机版
帮助中心