《PHP編程:php微信公眾平臺(tái)開發(fā)之微信群發(fā)信息》要點(diǎn):
本文介紹了PHP編程:php微信公眾平臺(tái)開發(fā)之微信群發(fā)信息,希望對您有用。如果有疑問,可以聯(lián)系我們。
1、目的PHP教程
完成在微信公眾號(hào)中群發(fā)消息.這里只是完成簡單的文字發(fā)送.也可以發(fā)送語音圖片等,只是發(fā)送數(shù)據(jù)格式不同而已,下面有鏈接,可以查詢數(shù)據(jù)類型的數(shù)據(jù)發(fā)送格式.PHP教程
2、群發(fā)短信的流程PHP教程
獲取測試公眾賬號(hào)(有賬號(hào)的可以不用測試賬號(hào),不過正式的賬號(hào)限制比較多)用戶關(guān)注上面的公眾賬號(hào)通過appid和appsecret獲取我們的access_token通過access_token群發(fā)短信PHP教程
3、獲取測試公眾賬號(hào) + 關(guān)注公眾號(hào)PHP教程
1)、公眾測試賬號(hào)獲取PHP教程
訪問上面的連接,選擇“接口測試號(hào)申請”獲得直接打開http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index通過微信客戶端掃碼登錄即可登錄.PHP教程
登錄完即可獲取到一個(gè)測試公眾賬號(hào)的信息.主要有appId和appsecret兩個(gè)參數(shù),這將唯一標(biāo)示一個(gè)公眾號(hào),并且需要將他們作為參數(shù)獲取用戶的信息.、PHP教程
PHP教程
2)、配置接口信息PHP教程
這一步可以參照微信接入說明,該頁提供一個(gè)php的實(shí)例下載,很簡單基本上修改一下自定義的TOKEN就好了,然后把驗(yàn)證頁面放到自己的服務(wù)器上.PHP教程
這里我提供我做的一個(gè)例子:PHP教程
準(zhǔn)備資源:PHP教程
域名+空間(我的是sae空間+萬網(wǎng)域名)、僅作驗(yàn)證的php文件PHP教程
域名指向的空間根目錄我創(chuàng)建了一個(gè)wx_sample.phpPHP教程
wx_sample.phpPHP教程
<?php /** * wechat php test */ //define your token define("TOKEN", "weixin"); $wechatObj = new wechatCallbackapiTest(); $wechatObj->valid(); class wechatCallbackapiTest { public function valid() { $echoStr = $_GET["echostr"]; //valid signature , option if($this->checkSignature()){ echo $echoStr; exit; } } public function responseMsg() { //get post data, May be due to the different environments $postStr = $GLOBALS["HTTP_RAW_POST_DATA"]; //extract post data if (!empty($postStr)){ /* libxml_disable_entity_loader is to prevent XML eXternal Entity Injection, the best way is to check the validity of xml by yourself */ libxml_disable_entity_loader(true); $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); $fromUsername = $postObj->FromUserName; $toUsername = $postObj->ToUserName; $keyword = trim($postObj->Content); $time = time(); $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[%s]]></MsgType> <Content><![CDATA[%s]]></Content> <FuncFlag>0</FuncFlag> </xml>"; if(!empty( $keyword )) { $msgType = "text"; $contentStr = "Welcome to wechat world!"; $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); echo $resultStr; }else{ echo "Input something..."; } }else { echo ""; exit; } } private function checkSignature() { // you must define TOKEN by yourself if (!defined("TOKEN")) { throw new Exception('TOKEN is not defined!'); } $signature = $_GET["signature"]; $timestamp = $_GET["timestamp"]; $nonce = $_GET["nonce"]; $token = TOKEN; $tmpArr = array($token, $timestamp, $nonce); // use SORT_STRING rule sort($tmpArr, SORT_STRING); $tmpStr = implode( $tmpArr ); $tmpStr = sha1( $tmpStr ); if( $tmpStr == $signature ){ return true; }else{ return false; } } } ?>
然后填寫配置信息Token (一定要與上面的wx_sample.php中的token一致)、URL(wx_sample.php的地址)PHP教程
PHP教程
然后提交就可以了PHP教程
如果提示失敗,請檢查Token與URL【如果是自己的域名和空間,請備案; 百度sae、新浪sae的需要自己申請而且認(rèn)證通過(就是自己拍一個(gè)手握證件照上傳,很簡單的 最短2天就o了),這一步必須】PHP教程
3)配置JS接口安全域名PHP教程
填這個(gè)域名是一定不要帶protocol的,比如說 http://www.sagosoft.com/ 這樣是不對的,這是URL不是域名PHP教程
域名應(yīng)該是類似 www.sagosoft.com這樣的 【否則在微信js-sdk接入時(shí)會(huì)提示invalid url domain】PHP教程
PHP教程
4)關(guān)注公眾號(hào)PHP教程
用戶只有關(guān)注了這個(gè)公眾號(hào)了,才能通過打開有公眾號(hào)信息的鏈接去授權(quán)第三方登錄,并獲取用戶信息的操作.故我們還需要用我們的微信關(guān)注微信號(hào),操作如下:PHP教程
還是剛剛那個(gè)登錄成功后跳轉(zhuǎn)的頁面,我們可以看到,該頁面有一個(gè)二維碼,我們可以通過掃描該二維碼進(jìn)行關(guān)注,關(guān)注成功在右邊的“用戶列表”會(huì)多一個(gè)用戶的信息.如下圖所示:PHP教程
PHP教程
5)配置回調(diào)函數(shù)PHP教程
我們在微信客戶端訪問第三方網(wǎng)頁(即我們自己的網(wǎng)頁)的時(shí)候,我們可以通過微信網(wǎng)頁授權(quán)機(jī)制,我們不僅要有前面獲取到的appid和appsecret還需要有當(dāng)用戶授權(quán)之后,回調(diào)的域名設(shè)置,即用戶授權(quán)后,頁面會(huì)跳轉(zhuǎn)到哪里.具體的配置如下:PHP教程
還是在剛剛的頁面,有一個(gè)“網(wǎng)頁授權(quán)獲取用戶基本信息”,點(diǎn)擊后面的修改PHP教程
PHP教程
填寫回調(diào)的域名:PHP教程
域名是上面配置的根域名,假如你上面 “接口配置信息” 填寫的url 為zcr.sinaaappc.com/wx_sample.php,這里只要填寫zcr.sinaaappc.com 就可以了.PHP教程
PHP教程
如果你的網(wǎng)址沒有被列入過黑名單,就會(huì)在頂部出現(xiàn)PHP教程
PHP教程
PHP教程
注意:PHP教程
1、這里填寫的是域名(是一個(gè)字符串),而不是URL,因此請勿加http://等協(xié)議頭;
2、授權(quán)回調(diào)域名配置規(guī)范為全域名,比如需要網(wǎng)頁授權(quán)的域名為:www.qq.com,配置以后此域名下面的頁面http://www.qq.com/music.html 、 http://www.qq.com/login.html 都可以進(jìn)行OAuth2.0鑒權(quán).但http://pay.qq.com 、 http://music.qq.com 、 http://qq.com無法進(jìn)行OAuth2.0鑒權(quán)PHP教程
到這里,我們就完成了公眾號(hào)測試賬號(hào)的獲取和配置,已經(jīng)用戶關(guān)注微信公眾號(hào).PHP教程
4、通過appid和appsecret獲取我們的access_tokenPHP教程
access_token是公眾號(hào)的全局唯一票據(jù),公眾號(hào)調(diào)用各接口時(shí)都需使用access_token.開發(fā)者需要進(jìn)行妥善保存.access_token的存儲(chǔ)至少要保留512個(gè)字符空間.access_token的有效期目前為2個(gè)小時(shí),需定時(shí)刷新,重復(fù)獲取將導(dǎo)致上次獲取的access_token失效.PHP教程
獲取方法:PHP教程
http請求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRETPHP教程
參數(shù)說明:PHP教程
PHP教程
正常情況下,微信會(huì)返回下述JSON數(shù)據(jù)包給公眾號(hào):PHP教程
PHP教程
錯(cuò)誤時(shí)微信會(huì)返回錯(cuò)誤碼等信息,JSON數(shù)據(jù)包示例如下(該示例為AppID無效錯(cuò)誤):PHP教程
例子:PHP教程
獲取access_token:PHP教程
返回?cái)?shù)據(jù):PHP教程
{ "access_token": "qR5UK2vMf5aTHV8e-uB10FZW0caTZm_1kbkUe4OPK2ILVvNaoa7pLzYWqLUAmx6Sjq1E7pKHrVAtuG0_1MPkqmDfOkm2750kaLWNk59DS-iDOpjjxompJtXa3WhbN5FKRWNhADAVAR", "expires_in": 7200 }
5、通過access_token群發(fā)短信PHP教程
在公眾平臺(tái)網(wǎng)站上,為訂閱號(hào)提供了每天一條的群發(fā)權(quán)限,為服務(wù)號(hào)提供每月(自然月)4條的群發(fā)權(quán)限.而對于某些具備開發(fā)能力的公眾號(hào)運(yùn)營者,可以通過高級群發(fā)接口,實(shí)現(xiàn)更靈活的群發(fā)能力.PHP教程
請注意:PHP教程
1、對于認(rèn)證訂閱號(hào),群發(fā)接口每天可成功調(diào)用1次,此次群發(fā)可選擇發(fā)送給全部用戶或某個(gè)分組;
2、對于認(rèn)證服務(wù)號(hào)雖然開發(fā)者使用高級群發(fā)接口的每日調(diào)用限制為100次,但是用戶每月只能接收4條,無論在公眾平臺(tái)網(wǎng)站上,還是使用接口群發(fā),用戶每月只能接收4條群發(fā)消息,多于4條的群發(fā)將對該用戶發(fā)送失敗;
3、具備微信支付權(quán)限的公眾號(hào),在使用群發(fā)接口上傳、群發(fā)圖文消息類型時(shí),可使用<a>標(biāo)簽加入外鏈;
4、開發(fā)者可以使用預(yù)覽接口校對消息樣式和排版,通過預(yù)覽接口可發(fā)送編輯好的消息給指定用戶校驗(yàn)效果.PHP教程
1)根據(jù)分組進(jìn)行群發(fā)【訂閱號(hào)與服務(wù)號(hào)認(rèn)證后均可用】PHP教程
調(diào)用接口:PHP教程
在body添加如下數(shù)據(jù)(以JSON格式數(shù)據(jù)發(fā)送)――發(fā)送其他格式數(shù)據(jù),只需要改里面參數(shù)信息即可,具體可查看微信官方文檔:PHP教程
{ "filter":{ "is_to_all":false, "group_id":2 }, "text":{ "content":"CONTENT" }, "msgtype":"text" }
參數(shù)說明: PHP教程
PHP教程
例子:發(fā)送給所有人PHP教程
url:PHP教程
發(fā)送的json數(shù)據(jù):發(fā)送給所有人PHP教程
{ "filter":{ "is_to_all":true }, "text":{ "content":"CONTENT" }, "msgtype":"text" }
返回?cái)?shù)據(jù):PHP教程
{ "errcode": 0, "errmsg": "send job submission success", "msg_id": 1000000003 }
參數(shù)意義:PHP教程
PHP教程
錯(cuò)誤碼及其以及查詢:PHP教程
全局錯(cuò)誤碼解析PHP教程
使用postman模擬https請求發(fā)送如下圖所示:PHP教程
PHP教程
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/3904.html