首页 > 微信应用  > 

Thinkphp整合微信支付功能详解

Thinkphp整合微信支付功能详解
微信支付现在在我们的生活中普遍皆是,在开发当中微信小程序也非常的火,本文我们继续给大家讲解关于Thinkphp整合微信支付功能。

微信支付现在在我们的生活中普遍皆是,在开发当中微信小程序也非常的火,本文我们继续给大家讲解关于thinkphp整合微信支付功能。

1、微信公众号:

  独特的appid、appscrect、接口权限之中设置可以获取用户ID信息权限的域名(每个用户对于不同公众都会有一个特有ID,通过这个ID获取用户微信账号基本信息、详情看微信开发者文档)、在微信支付按钮出设置微信支付授权目录(写到发起请求的控制器那一层)、设置开发者微信账号为测试白名单(用微信开发者工具的时候需要)

2、微信支付平台:

  商户平台登陆账号、支付密钥(随时可以自行设置,只能有一个)、

3、整合进去thinkphp之中逻辑:

  前端微信支付按钮设置点击调用支付发起控制器方法、

  控制器运行,引用微信支付类、获取用户openid、获取订单数据、拼接出所有普通商户预支付jsp需要的数据,display出那个自定义的支付页面、

  在支付页面点击支付、调用微信提供的jspi发起支付的scripet函数发起支付、

  支付完成以后页面会重定向到(在自定义支付页面的script函数里设置的跳转目录{:U('controller/function)}),并且异步(静默)设置的异步处理订单逻辑(记录支付时间啦、标记为已经支付啦、标记是微信支付啦)之类的、

代码:

  我的订单页面的微信支付按钮:

微信支付

发起支付控制器Wxpay:

<?phpnamespace Home\Controller;use Think\Controller;//微信支付类class WxpayController extends Controller { //获取access_token过程中的跳转uri,通过跳转将code传入jsapi支付页面 public function js_api_start(){ if(!empty($_GET[&#39;order_key_num&#39;])){ // session(array(&#39;pay_now_id&#39;=>$_GET[&#39;order_key_num&#39;],&#39;expire&#39;=>3600)); S(&#39;pay_now_id&#39;,$_GET[&#39;order_key_num&#39;],3600); } vendor(&#39;Weixinpay.WxPayPubHelper&#39;); //使用jsapi接口 $jsApi = new \JsApi_pub(); //=========步骤1:网页授权获取用户openid============ //通过code获得openid if($_GET[&#39;code&#39;] == &#39;&#39;){ //跳转 $redirect_uri = &#39;https://当前域名+模块+控制器+方法&#39;; $url = &#39;https://open.weixin.qq.com/connect/oauth2/authorize ?appid=公众号特有IDredirect_uri=&#39;.$redirect_uri.&#39;&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect&#39;; header("Location: $url"); exit(); }else{ //获取openid $url = &#39;https://api.weixin.qq.com/sns/oauth2/access_token ?appid=公众号ID&secret=公众号scrept&code=&#39;.$_GET[&#39;code&#39;].&#39;&grant_type=authorization_code&#39;; $openid_arr = json_decode(file_get_contents($url),true); } $openid=$openid_arr[&#39;openid&#39;]; $pay_now_id = S(&#39;pay_now_id&#39;); if($pay_now_id){ $id=$pay_now_id; $o = D(&#39;order_info&#39;); $order_info = $o->where(&#39;order_id = %d&#39;,$id)->find(); if(empty($order_info[&#39;paycode&#39;])){ $order_info[&#39;paycode&#39;] = &#39;weixin&#39;; } if($order_info[&#39;is_pay&#39;]){ $this->error(&#39;当前订单已经支付&#39;); } }else{ $this->error("不存在当前订单编号!"); } $res = array( &#39;order_sn&#39; => $order_info[&#39;order_sn&#39;], &#39;order_amount&#39; => $order_info[&#39;pay_money&#39;] ); //=========步骤2:使用统一支付接口,获取prepay_id============ //使用统一支付接口 $unifiedOrder = new \UnifiedOrder_pub(); //设置统一支付接口参数 //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //spbill_create_ip已填,商户无需重复填写 //sign已填,商户无需重复填写 $total_fee = $order_info[&#39;pay_money&#39;]*100; // $total_fee = $res[&#39;order_amount&#39;]; //$total_fee = 1; // var_dump($order_info[&#39;pay_money&#39;]);die; $body = "订单支付"; $unifiedOrder->setParameter("openid", "$openid");//用户标识 $unifiedOrder->setParameter("body", &#39;商品采购&#39;);//商品描述 //自定义订单号,此处仅作举例 $unifiedOrder->setParameter("out_trade_no", $order_info[&#39;order_sn&#39;]);//商户订单号 $unifiedOrder->setParameter("total_fee", $total_fee);//总金额 //$unifiedOrder->setParameter("attach", "order_sn={$res[&#39;order_sn&#39;]}");//附加数据 $unifiedOrder->setParameter("notify_url", \WxPayConf_pub::NOTIFY_URL);//通知地址 $unifiedOrder->setParameter("trade_type", "JSAPI");//交易类型 //非必填参数,商户可根据实际情况选填 //$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");//用户标识 //$unifiedOrder->setParameter("product_id","XXXX");//商品ID $prepay_id = $unifiedOrder->getPrepayId(); // var_dump($prepay_id);die; //=========步骤3:使用jsapi调起支付============ $jsApi->setPrepayId($prepay_id); $jsApiParameters = $jsApi->getParameters(); $wxconf = json_decode($jsApiParameters, true); if ($wxconf[&#39;package&#39;] == &#39;prepay_id=&#39;) { $this->error(&#39;当前订单存在异常!&#39;); } $this->assign(&#39;res&#39;, $res); $this->assign(&#39;jsApiParameters&#39;, $jsApiParameters); $this->display(&#39;jsapi&#39;); } //异步通知url,商户根据实际开发过程设定 public function notify_url() { vendor(&#39;Weixinpay.WxPayPubHelper&#39;); //使用通用通知接口 $notify = new \Notify_pub(); //存储微信的回调 $xml = $GLOBALS[&#39;HTTP_RAW_POST_DATA&#39;]; $notify->saveData($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(); //==商户根据实际情况设置相应的处理流程,此处仅作举例======= //以log文件形式记录回调信息 //$log_name = "notify_url.log";//log文件路径 //$this->log_result($log_name, "【接收到的notify通知】:\n".$xml."\n"); $parameter = $notify->xmlToArray($xml); //$this->log_result($log_name, "【接收到的notify通知】:\n".$parameter."\n"); if($notify->checkSign() == TRUE){ if ($notify->data["return_code"] == "FAIL") { //此处应该更新一下订单状态,商户自行增删操作 //$this->log_result($log_name, "【通信出错】:\n".$xml."\n"); //更新订单数据【通信出错】设为无效订单 echo &#39;error&#39;; } else if($notify->data["result_code"] == "FAIL"){ //此处应该更新一下订单状态,商户自行增删操作 //$this->log_result($log_name, "【业务出错】:\n".$xml."\n"); //更新订单数据【通信出错】设为无效订单 echo &#39;error&#39;; } else{ //$this->log_result($log_name, "【支付成功】:\n".$xml."\n"); //我这里用到一个process方法,成功返回数据后处理,返回地数据具体可以参考微信的文档 if ($this->process($parameter)) { //处理成功后输出success,微信就不会再下发请求了 echo &#39;success&#39;; }else { //没有处理成功,微信会间隔的发送请求 echo &#39;error&#39;; } } } } //订单处理 private function process($parameter) { //此处应该更新一下订单状态,商户自行增删操作 /* * 返回的数据最少有以下几个 * $parameter = array( &#39;out_trade_no&#39; => xxx,//商户订单号 &#39;total_fee&#39; => XXXX,//支付金额 &#39;openid&#39; => XXxxx,//付款的用户ID ); */ $data = array( &#39;order_sn&#39;=>$parameter[&#39;out_trade_no&#39;], &#39;des&#39;=>(&#39;订单交易:&#39;.$parameter[&#39;out_trade_no&#39;]), &#39;money&#39;=>$parameter[&#39;total_fee&#39;], ); orderhandlestarysdgdss($data);//这是一个common方法,他会将该订单状态设置为已支付之类的 return true; }}?>

Thinkphp整合微信支付功能详解由讯客互联微信应用栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“Thinkphp整合微信支付功能详解