本文為大家分享了PHP實現(xiàn)微信商戶支付企業(yè)付款到零錢的具體代碼,供大家參考,具體內(nèi)容如下微信支付開發(fā)文檔一、開通條件企業(yè)付款為企業(yè)提供付款至用戶零錢的能力,支持通過API接口付款,或通過微信支付商戶平臺......
以下是【金聰采編】分享的內(nèi)容全文:
以下是【金聰采編】分享的內(nèi)容全文:
本文實例為大家分享了APP微信提現(xiàn)接口的具體代碼,供大家參考,具體內(nèi)容如下
之前分享了微信支付接口、現(xiàn)在給大家分享一下APP提現(xiàn)的接口。
提現(xiàn)必須得用雙向證書、所以大家一定要在微信的商戶平臺找到相應(yīng)的地方去設(shè)置、因為我做這個提現(xiàn)已經(jīng)有一段時間了、所以設(shè)置微信商戶平臺的那幾個地方?jīng)]有圖的情況、也說不清楚、下次再做提現(xiàn)的時候、給大家分享如何設(shè)置商戶平臺那幾個地方、不是很難、下面貼代碼
<?phpnamespace Home/Controller;use Think/Controller;class TixianController extends Controller{ //高級功能-》開發(fā)者模式-》獲取 private $app_id1 = ''; //appid private $app_secret1 = ''; //secreat private $apikey1 = ''; //支付秘鑰 private $mchid1 = 's'; //商戶號 private $app_id=null; private $app_secret=null; private $apikey=null; private $mchid=null; public $error=0; public $state = ''; //金額,需在實例化時傳入 public $amount = '0'; //用戶訂單號,需在實例化時傳入 public $order_sn = ''; //用戶openid,需在實例化時傳入 public $openid = ''; //微信提現(xiàn)操作接口-------》 public function actionAct_tixian() { $this->state=md5(uniqid(rand(), TRUE)); $this->amount=I('amount');//設(shè)置POST過來錢數(shù) $this->order_sn=rand(100,999).date('YmdHis'); //隨機數(shù)可以作為單號 $this->openid= I('openid'); //設(shè)置獲取POST過來用戶的OPENID $user_id = I('user_id'); $this->app_id=$this->app_id1; $this->app_secret=$this->app_secret1; $this->apikey=$this->apikey1; $this->mchid=$this->mchid1; $xml=$this->tiXianAction(); $result=simplexml_load_string($xml); if($result->return_code=='SUCCESS' && $result->result_code=='SUCCESS') { $cash = D('cash'); $data['user_id'] = $user_id; $data['amount'] = $this->amount; $res = $cash->where('user_id="'.$user_id.'"')->find(); if($res){ $res2 = $cash->where('user_id="'.$user_id.'"')->setInc('amount',$this->amount); $res4 = D('member')->where('user_id="'.$user_id.'"')->setDec('user_balance',$this->amount); }else{ $res3 = $cash->add($data); } $output = array('code' => 1, 'data' => $result->result_code, 'info' => '提現(xiàn)成功'); exit(json_encode($output)); }else{ $output = array('code' => 2, 'data' => $xml, 'info' => '提現(xiàn)失敗'); exit(json_encode($output)); } } /** * 提現(xiàn)接口操作,控制器調(diào)用 * @param $openid 用戶openid 唯一標示 * @return */ //提現(xiàn)接口操作 public function tiXianAction(){ //獲取xml數(shù)據(jù) $data=$this->getdataXml($this->openid); $ch = curl_init (); //接口地址 $MENU_URL="https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers"; curl_setopt ( $ch, CURLOPT_URL, $MENU_URL ); curl_setopt ( $ch, CURLOPT_CUSTOMREQUEST, "POST" ); curl_setopt ( $ch, CURLOPT_SSL_VERIFYPEER, FALSE ); curl_setopt ( $ch, CURLOPT_SSL_VERIFYHOST, FALSE ); //證書地址,微信支付下面 curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM'); curl_setopt($ch,CURLOPT_SSLCERT, 'C:/web/www/Home/wx_pay/apiclient_cert.pem'); //證書這塊大家把文件放到哪都行、 curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM'); curl_setopt($ch,CURLOPT_SSLKEY, 'C:/web/www/Home/wx_pay/apiclient_key.pem');//注意證書名字千萬別寫錯、 //$zs1=dirname(dirname(__FILE__)).'/wx_pay/apiclient_cert.pem'; //$zs2=dirname(dirname(__FILE__)).'/wx_pay/apiclient_key.pem'; //show_bug($zs1); //curl_setopt($ch,CURLOPT_SSLCERT,$zs1); //curl_setopt($ch,CURLOPT_SSLKEY,$zs2); // curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; // Windows NT 5.0)'); //curl_setopt ( $ch, CURLOPT_FOLLOWLOCATION, 1 ); curl_setopt ( $ch, CURLOPT_AUTOREFERER, 1 ); curl_setopt ( $ch, CURLOPT_POSTFIELDS, $data ); curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, true ); $info = curl_exec ( $ch ); //返回結(jié)果 if($info){ curl_close($ch); return $info; } else { $error = curl_errno($ch); curl_close($ch); return "curl出錯,錯誤碼:$error"; } } /** * 獲取數(shù)據(jù)封裝為數(shù)組 * @param $openid 用戶openid 唯一標示 * @return xml */ private function getdataXml($openid){ //封裝成數(shù)據(jù) $dataArr=array( 'amount'=>$this->amount*100,//金額(以分為單位,必須大于100) 'check_name'=>'NO_CHECK',//校驗用戶姓名選項,NO_CHECK:不校驗真實姓名 FORCE_CHECK:強校驗真實姓名(未實名認證的用戶會校驗失敗,無法轉(zhuǎn)賬)OPTION_CHECK:針對已實名認證的用戶才校驗真實姓名(未實名認證用戶不校驗,可以轉(zhuǎn)賬成功) 'desc'=>'提現(xiàn)',//描述 'mch_appid'=>$this->app_id, 'mchid'=>$this->mchid,//商戶號 'nonce_str'=>rand(100000, 999999),//不長于32位的隨機數(shù) 'openid'=>$openid,//用戶唯一標識 'partner_trade_no'=>$this->order_sn,//商戶訂單號 're_user_name'=>'',//用戶姓名,check_name為NO_CHECK時為可選項 'spbill_create_ip'=>$_SERVER["REMOTE_ADDR"],//服務(wù)器ip ); //獲取簽名 $sign=$this->getSign($dataArr); //xml數(shù)據(jù) $data="<xml> <mch_appid>".$dataArr['mch_appid']."</mch_appid> <mchid>".$dataArr['mchid']."</mchid> <nonce_str>".$dataArr['nonce_str']."</nonce_str> <partner_trade_no>".$dataArr['partner_trade_no']."</partner_trade_no> <openid>".$dataArr['openid']."</openid> <check_name>".$dataArr['check_name']."</check_name> <re_user_name>".$dataArr['re_user_name']."</re_user_name> <amount>".$dataArr['amount']."</amount> <desc>".$dataArr['desc']."</desc> <spbill_create_ip>".$dataArr['spbill_create_ip']."</spbill_create_ip> <sign>".$sign."</sign> </xml>"; return $data; } /** * 作用:格式化參數(shù),簽名過程需要使用 */ private function formatBizQueryParaMap($paraMap, $urlencode) { $buff = ""; ksort($paraMap); foreach ($paraMap as $k => $v) { if($v){ if($urlencode) { $v = urlencode($v); } $buff .= $k . "=" . $v . "&"; } } $reqPar=NULL; if (strlen($buff) > 0) { $reqPar = substr($buff, 0, strlen($buff)-1); } return $reqPar; } /** * 作用:生成簽名 */ private function getSign($Obj) { foreach ($Obj as $k => $v) { $Parameters[$k] = $v; } //簽名步驟一:按字典序排序參數(shù) ksort($Parameters); $String = $this->formatBizQueryParaMap($Parameters, false); //echo '【string1】'.$String.'</br>'; //簽名步驟二:在string后加入KEY $String = $String."&key=".$this->apikey; //echo "【string2】".$String."</br>"; //簽名步驟三:MD5加密 $String = md5($String); //echo "【string3】 ".$String."</br>"; //簽名步驟四:所有字符轉(zhuǎn)為大寫 $result_ = strtoupper($String); //echo "【result】 ".$result_."</br>"; return $result_; } //----------- private function http($url, $method='POST', $postfields = null, $headers = array()) { header("Content-Type:text/html;charset=utf-8"); $ch = curl_init(); /* Curl settings */ curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_POSTFIELDS, ""); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); // https請求 不驗證證書和hosts curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); curl_setopt($ch, CURLOPT_TIMEOUT, 30); switch ($method){ case 'POST': curl_setopt($ch,CURLOPT_POST, true); break; } curl_setopt($ch, CURLOPT_HTTPHEADER,$headers); curl_setopt($ch, CURLINFO_HEADER_OUT, true); $response = curl_exec($ch); $http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE); //返回請求狀態(tài)碼 curl_close($ch); return array($http_code, $response); }}以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持金聰精品。
金聰線報提示:[ PHP實現(xiàn)微信商戶支付企業(yè)付款到零錢功能 ] 僅為會員分享,分享目的如下:
1.軟件源碼推廣展示:目的展示軟件相關(guān)功能,接收技術(shù)學習者測試、測評;
2.教程課程信息展示:展示課程信息,傳授課程各階段內(nèi)容;
3.設(shè)計素材圖片展示:展示素材設(shè)計理念、思維方式、傳播設(shè)計理念;
4.福利優(yōu)惠信息展示:分享各類最新的福利信息,各種優(yōu)惠信息展示;
以上分享目的僅供學習、參考使用,請勿用于其他用途,如果想商業(yè)使用或者代理,請自行聯(lián)系版權(quán)方獲取授權(quán)。任何未獲取授權(quán)的商業(yè)使用與本站無關(guān),請自行承擔相應(yīng)責任。
本站不存儲任何資源文件,敬請周知!
本網(wǎng)站采用 BY-NC-SA 協(xié)議進行授權(quán) 轉(zhuǎn)載請注明原文鏈接:PHP實現(xiàn)微信商戶支付企業(yè)付款到零錢功能
1.軟件源碼推廣展示:目的展示軟件相關(guān)功能,接收技術(shù)學習者測試、測評;
2.教程課程信息展示:展示課程信息,傳授課程各階段內(nèi)容;
3.設(shè)計素材圖片展示:展示素材設(shè)計理念、思維方式、傳播設(shè)計理念;
4.福利優(yōu)惠信息展示:分享各類最新的福利信息,各種優(yōu)惠信息展示;
以上分享目的僅供學習、參考使用,請勿用于其他用途,如果想商業(yè)使用或者代理,請自行聯(lián)系版權(quán)方獲取授權(quán)。任何未獲取授權(quán)的商業(yè)使用與本站無關(guān),請自行承擔相應(yīng)責任。
本站不存儲任何資源文件,敬請周知!
此資源僅供個人學習、研究使用,禁止非法轉(zhuǎn)播或商業(yè)用途,請在獲取后24小時內(nèi)刪除,如果你覺得滿意,請尋求購買正版或獲取授權(quán)!
如果您認為本頁信息內(nèi)容侵犯了您的相關(guān)權(quán)益(包含但不限于:著作權(quán)、首發(fā)權(quán)、隱私權(quán)等權(quán)利),或者您認為自己是此信息的權(quán)利人但是此信息不是自己發(fā)布的,可以直接版權(quán)舉報投訴,我們會根據(jù)網(wǎng)站注冊協(xié)議、資源分享協(xié)議等協(xié)議處理,以保護您的合法權(quán)益。
免責申明:本站僅提供學習的平臺,所有資料均來自于網(wǎng)絡(luò)分享線索,版權(quán)歸原創(chuàng)者所有!本站不提供任何保證,并不承擔任何法律責任,如果對您的版權(quán)或者利益造成損害,請?zhí)峁┫鄳?yīng)的資質(zhì)證明,我們將于3個工作日內(nèi)予以處理。版權(quán)申訴相關(guān)說明如果您認為本頁信息內(nèi)容侵犯了您的相關(guān)權(quán)益(包含但不限于:著作權(quán)、首發(fā)權(quán)、隱私權(quán)等權(quán)利),或者您認為自己是此信息的權(quán)利人但是此信息不是自己發(fā)布的,可以直接版權(quán)舉報投訴,我們會根據(jù)網(wǎng)站注冊協(xié)議、資源分享協(xié)議等協(xié)議處理,以保護您的合法權(quán)益。
本網(wǎng)站采用 BY-NC-SA 協(xié)議進行授權(quán) 轉(zhuǎn)載請注明原文鏈接:PHP實現(xiàn)微信商戶支付企業(yè)付款到零錢功能

侵權(quán)舉報/版權(quán)申訴



