上期咱們講完了微信開放平臺(tái)開發(fā)者帳號(hào)注冊(cè)以及第三方平臺(tái)的創(chuàng)建工作呛凶,從今天開始独旷,咱們就開始正式的開發(fā)部分咯筐高,跟進(jìn)袁小威的腳步把还,莫掉隊(duì)哦~~~
在第三方平臺(tái)創(chuàng)建審核通過(guò)之后后,微信服務(wù)器會(huì)每隔10分鐘定時(shí)向“授權(quán)事件接收URL”推送component_verify_ticket兔港,第三方平臺(tái)方收到component_verify_ticket推送后需對(duì)其進(jìn)行解密操作绳泉,且在接收到之后必須直接返回字符串success(這個(gè)推送過(guò)來(lái)的component_verify_ticket很重要募判,這在第三方平臺(tái)后續(xù)功能實(shí)現(xiàn)上都需要用到)挡爵。
微信服務(wù)器將信息用XML數(shù)據(jù)格式竖般,以POST方式推送到我們的服務(wù)器,官方有提供相應(yīng)的數(shù)據(jù)示例以及字段說(shuō)明茶鹃。
POST數(shù)據(jù)示例
<xml>
<AppId></AppId>
<CreateTime>1413192605</CreateTime>
<InfoType></InfoType>
<ComponentVerifyTicket></ComponentVerifyTicket>
</xml>
字段說(shuō)明
字段名稱 | 字段描述 |
---|---|
AppId | 第三方平臺(tái)appid |
CreateTime | 時(shí)間戳 |
InfoType | component_verify_ticket |
ComponentVerifyTicket | Ticket內(nèi)容 |
這一步也是折騰我最久的地方涣雕,主要問(wèn)題就是推送過(guò)來(lái)的信息是加密的我們需要先將信息解密,解密出component_verify_ticket后將該ticket保存起來(lái)闭翩。
不過(guò)這部分官方有提供相應(yīng)語(yǔ)言的解密DEMO挣郭,下面附上我自己這塊的完整代碼,里面用到了數(shù)據(jù)庫(kù)操作以及微信公眾號(hào)取消授權(quán)的操作:
public function ticket(){
require_once(dirname(__FILE__).'/wxBizMsgCrypt.php');//該文件在官方demo里面男杈,下載后引入進(jìn)來(lái)就可以了
$encodingAesKey = '';//創(chuàng)建平臺(tái)時(shí)填寫的公眾號(hào)消息加解密Key
$token = '';//創(chuàng)建平臺(tái)時(shí)填寫的公眾號(hào)消息校驗(yàn)Token
$appId = '';//公眾號(hào)第三方平臺(tái)AppID
$timeStamp = empty ( $_GET ['timestamp']) ? "" : trim ( $_GET ['timestamp'] );
$nonce = empty ( $_GET ['nonce'] ) ?"" : trim ( $_GET ['nonce'] );
$msg_sign = empty ( $_GET['msg_signature'] ) ? "" : trim ( $_GET ['msg_signature'] );
$encryptMsg = file_get_contents ('php://input' );
$pc = new \WXBizMsgCrypt ( $token,$encodingAesKey, $appId );
// 第三方收到公眾號(hào)平臺(tái)發(fā)送的消息
$msg = '';
$errCode = $pc->decryptMsg ($msg_sign, $timeStamp, $nonce, $encryptMsg, $msg );
if ($errCode == 0) {
$data = $this->_xmlToArr ( $msg);
if (isset ( $data['ComponentVerifyTicket'] )) {
$config['componentverifyticket'] = $data ['ComponentVerifyTicket'];
$config['create_time'] =date("Y-m-d H:i:s");
$where['id']= '1';
M('Public')->where($where)->setField($config);
} elseif ($data ['InfoType'] =='unauthorized') {
// 在公眾號(hào)后臺(tái)取消授權(quán)后丈屹,同步把系統(tǒng)里的公眾號(hào)刪除掉调俘,并更新相關(guān)用戶緩存
$map ['appid'] = $data['AuthorizerAppid'];
$map2 ['id'] = M ('WechatPublic' )->where ( $map )->getField ( 'id' );
if ($map2 ['id']) {
M ( 'WechatPublic')->where ( $map2 )->delete();
}
}
echo 'success';
} else {
echo '解密失敗'.$errCode;
}
}
public function _xmlToArr($xml) {
$res = @simplexml_load_string ( $xml,NULL, LIBXML_NOCDATA );
$res = json_decode ( json_encode ( $res), true );
return $res;
}
后面接收微信服務(wù)推送的消息都需要解密伶棒,該方法都可以解密。
PS:初次寫這種類型的內(nèi)容彩库,語(yǔ)言表達(dá)什么的如果有什么問(wèn)題肤无,還希望大家能夠多多包涵~~