PHP微信公眾號開發(fā)之微信紅包實(shí)現(xiàn)方法分析
本文實(shí)例講述了PHP微信公眾號開發(fā)之微信紅包實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
這幾天遇到了一個(gè)客戶 要給他們的微信公眾平臺上添加微信現(xiàn)金紅包功能,是個(gè)二次開發(fā)的功能,順手百度一下,原來不復(fù)雜。就著手開發(fā)功能了?,F(xiàn)將開發(fā)的過程和需求貼出來分享一下:
一.需求:
粉絲通過在客戶的公眾平臺點(diǎn)擊他們公司的訂單,然后給這個(gè)訂單返現(xiàn)五元,發(fā)到訂單的這個(gè)微信號上。
二.開發(fā)想法:
1:先拿到關(guān)注這個(gè)粉絲的openid,openid是關(guān)注某個(gè)公眾號的微信標(biāo)識,這樣就可以定位到這個(gè)人是訂單的操作者了。
2:發(fā)送xml數(shù)據(jù)請求微信服務(wù)器。
代碼有兩個(gè)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>錯(cuò)誤1</h1>'.$token->errcode;
echo '<br/><h2>錯(cuò)誤信息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'];
//活動(dòng)名稱
$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中spl_autoload_register()函數(shù)用法實(shí)例詳解
這篇文章主要介紹了PHP中spl_autoload_register()函數(shù)用法,結(jié)合實(shí)例形式分析了__autoload函數(shù)及spl_autoload_register函數(shù)的相關(guān)使用技巧,需要的朋友可以參考下2016-07-07
php使用curl代理實(shí)現(xiàn)抓取數(shù)據(jù)的方法
這篇文章主要介紹了php使用curl代理實(shí)現(xiàn)抓取數(shù)據(jù)的方法,結(jié)合實(shí)例形式分析了php使用curl實(shí)現(xiàn)代理抓取數(shù)據(jù)的操作技巧,需要的朋友可以參考下2017-02-02
php下mysql數(shù)據(jù)庫操作類(改自discuz)
這是php mysql的數(shù)據(jù)庫操作類,取自discuz,經(jīng)過修改后可以用于其它程序了,并且有足夠的注釋,大家可以借鑒研究下.2010-07-07
PHP函數(shù)shuffle()取數(shù)組若干個(gè)隨機(jī)元素的方法分析
這篇文章主要介紹了PHP函數(shù)shuffle()取數(shù)組若干個(gè)隨機(jī)元素的方法,結(jié)合實(shí)例形式詳細(xì)分析了shuffle函數(shù)的功能,定義,使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-04-04

