PHP微信公眾號開發(fā)之微信紅包實(shí)現(xiàn)方法分析
本文實(shí)例講述了PHP微信公眾號開發(fā)之微信紅包實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
這幾天遇到了一個客戶 要給他們的微信公眾平臺上添加微信現(xiàn)金紅包功能,是個二次開發(fā)的功能,順手百度一下,原來不復(fù)雜。就著手開發(fā)功能了?,F(xiàn)將開發(fā)的過程和需求貼出來分享一下:
一.需求:
粉絲通過在客戶的公眾平臺點(diǎn)擊他們公司的訂單,然后給這個訂單返現(xiàn)五元,發(fā)到訂單的這個微信號上。
二.開發(fā)想法:
1:先拿到關(guān)注這個粉絲的openid,openid是關(guān)注某個公眾號的微信標(biāo)識,這樣就可以定位到這個人是訂單的操作者了。
2:發(fā)送xml數(shù)據(jù)請求微信服務(wù)器。
代碼有兩個php文件
1.oauth2.php
<?php $code=$_GET['code']; $state=$_GET['state']; $appid='XXXX'; $appsecret='XXXXXXXX';// if (empty($code)) $this->error('授權(quán)失敗'); $token_url='https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$appid'&secret='.$appsecret.'&code='.$code.'&grant_type=authorization_code'; $token=json_decode(file_get_contents($token_url)); if (isset($token->errcode)) { echo '<h1>錯誤1</h1>'.$token->errcode; echo '<br/><h2>錯誤信息1:</h2>'.$token->errmsg; exit; } session_start(); $_SESSION['openid']= $token->openid; header('location:http://www.XXXXXXX.com/XXXXX/XXXXXX/XXXXXX/hongbao.php');//要跳轉(zhuǎn)的文件路徑 ?>
2.hongbao.php
<?php //XXXXX。。是需要開發(fā)者自己填寫的內(nèi)容,注意不要泄密 // 從session中獲取到openid; $openid=$_SESSION["openid"]; if(empty($openid)) { header('location:https://open.weixin.qq.com/connect/oauth2/authorize?appid=XXXXXXXX&redirect_uri=http://www.XXXXXXX.com/oauth2.php&respose_type=code&scope=snsapi_base&state=XXXX&connect_redirect=1#wechat_redirect'); } } // 關(guān)鍵的函數(shù) public function weixin_red_packet(){ // 請求參數(shù) // 隨機(jī)字符串 $data['nonce_str']=$this->get_unique_value(); //商戶號,輸入你的商戶號 $data['mch_id']="XXXXXXX"; //商戶訂單號,可以按要求自己組合28位的商戶訂單號 $data['mch_billno']=$data['mch_id'].date("ymd")."XXXXXX".rand(1000,9999); //公眾帳號appid,輸入自己的公眾號appid $data['wxappid']="XXXXXXX"; //商戶名稱 $data['send_name']="XXXXX"; //用戶openid,輸入待發(fā)紅包的用戶openid session_start(); $data['re_openid']=$_SESSION["openid"]; //付款金額 $data['total_amount']="XXXX"; //紅包發(fā)放總?cè)藬?shù) $data['total_num']="XXXX"; //紅包祝福語 $data['wishing']="XXXX"; //IP地址 $data['client_ip']=$_SERVER['LOCAL_ADDR']; //活動名稱 $data['act_name']="XXXXX"; //備注 $data['remark']="XXXXX"; // 生成簽名 //對數(shù)據(jù)數(shù)組進(jìn)行處理 //API密鑰,輸入自己的K 微信商戶號里面的K $appsecret="XXXXXXXXXXXXXX"; // $data=array_filter($data); ksort($data); $str=""; foreach($data as $k=>$v){ $str.=$k."=".$v."&"; } $str.="key=".$appsecret; $data['sign']=strtoupper(MD5($str)); /* 發(fā)紅包操作過程: 1.將請求數(shù)據(jù)轉(zhuǎn)換成xml 2.發(fā)送請求 3.將請求結(jié)果轉(zhuǎn)換為數(shù)組 4.將請求信息和請求結(jié)果錄入到數(shù)據(jù)庫中 4.判斷是否通信成功 5.判斷是否轉(zhuǎn)賬成功 */ //發(fā)紅包接口地址 $url="https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack"; //將請求數(shù)據(jù)由數(shù)組轉(zhuǎn)換成xml $xml=$this->arraytoxml($data); //進(jìn)行請求操作 $res=$this->curl($xml,$url); //將請求結(jié)果由xml轉(zhuǎn)換成數(shù)組 $arr=$this->xmltoarray($res); } // 生成32位唯一隨機(jī)字符串 private function get_unique_value(){ $str=uniqid(mt_rand(),1); $str=sha1($str); return md5($str); } // 將數(shù)組轉(zhuǎn)換成xml private function arraytoxml($arr){ $xml="<xml>"; foreach($arr as $k=>$v){ $xml.="<".$k.">".$v."</".$k.">"; } $xml.="</xml>"; return $xml; } // 將xml轉(zhuǎn)換成數(shù)組 private function xmltoarray($xml){ //禁止引用外部xml實(shí)體 libxml_disable_entity_loader(true); $xmlstring=simplexml_load_string($xml,"SimpleXMLElement",LIBXML_NOCDATA); $arr=json_decode(json_encode($xmlstring),true); return $arr; } //進(jìn)行curl操作 private function curl($param="",$url) { $postUrl = $url; $curlPost = $param; //初始化curl $ch = curl_init(); //抓取指定網(wǎng)頁 curl_setopt($ch, CURLOPT_URL,$postUrl); //設(shè)置header curl_setopt($ch, CURLOPT_HEADER, 0); //要求結(jié)果為字符串且輸出到屏幕上 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //post提交方式 curl_setopt($ch, CURLOPT_POST, 1); // 增加 HTTP Header(頭)里的字段 curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost); // 終止從服務(wù)端進(jìn)行驗(yàn)證 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); //證書放到網(wǎng)站根目錄的cert文件夾底下 curl_setopt($ch,CURLOPT_SSLCERT,dirname(__FILE__).DIRECTORY_SEPARATOR. 'cert'.DIRECTORY_SEPARATOR.'apiclient_cert.pem'); curl_setopt($ch,CURLOPT_SSLKEY,dirname(__FILE__).DIRECTORY_SEPARATOR. 'cert'.DIRECTORY_SEPARATOR.'apiient_key.pem'); curl_setopt($ch,CURLOPT_CAINFO,dirname(__FILE__).DIRECTORY_SEPARATOR. 'cert'.DIRECTORY_SEPARATOR.'rootca.pem'); //運(yùn)行curl $data = curl_exec($ch); //關(guān)閉curl curl_close($ch); return $data; } ?>
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP微信開發(fā)技巧匯總》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語法入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP使用PDO訪問oracle數(shù)據(jù)庫的步驟詳解
POD擴(kuò)展是在PHP5中加入,該擴(kuò)展提供PHP內(nèi)置類 PDO來對數(shù)據(jù)庫進(jìn)行訪問,不同數(shù)據(jù)庫使用相同的方法名,解決數(shù)據(jù)庫連接不統(tǒng)一的問題。下面這篇文章主要給大家介紹了關(guān)于PHP使用PDO訪問oracle數(shù)據(jù)庫的步驟,需要的朋友可以參考下。2017-09-09php heredoc和phpwind的模板技術(shù)使用方法小結(jié)
Heredoc技術(shù),在正規(guī)的PHP文檔中和技術(shù)書籍中一般沒有詳細(xì)講述,只是提到了這是一種Perl風(fēng)格的字符串輸出技術(shù)。但是現(xiàn)在的一些論壇程序,和部分文章系統(tǒng),都巧妙的使用heredoc技術(shù),來部分的實(shí)現(xiàn)了界面與代碼的準(zhǔn)分離,phpwind就是一個典型的例子。2008-03-03PHP has encountered an Access Violation at 7C94BD02解決方法
PHP has encountered an Access Violation at 7C94BD02解決方法2009-08-08PHP字符串函數(shù)系列之nl2br(),在字符串中的每個新行 (\n) 之前插入 HTML 換行符br
nl2br() 函數(shù)在字符串中的每個新行 (\n) 之前插入 HTML 換行符 (br)。2011-11-11