php微信公眾平臺(tái)開(kāi)發(fā)之微信群發(fā)信息
1、目的
完成在微信公眾號(hào)中群發(fā)消息。這里只是完成簡(jiǎn)單的文字發(fā)送。也可以發(fā)送語(yǔ)音圖片等,只是發(fā)送數(shù)據(jù)格式不同而已,下面有鏈接,可以查詢數(shù)據(jù)類型的數(shù)據(jù)發(fā)送格式。
2、群發(fā)短信的流程
獲取測(cè)試公眾賬號(hào)(有賬號(hào)的可以不用測(cè)試賬號(hào),不過(guò)正式的賬號(hào)限制比較多)用戶關(guān)注上面的公眾賬號(hào)通過(guò)appid和appsecret獲取我們的access_token通過(guò)access_token群發(fā)短信
3、獲取測(cè)試公眾賬號(hào) + 關(guān)注公眾號(hào)
1)、公眾測(cè)試賬號(hào)獲取
訪問(wèn)上面的連接,選擇“接口測(cè)試號(hào)申請(qǐng)”獲得直接打開(kāi)http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index通過(guò)微信客戶端掃碼登錄即可登錄。
登錄完即可獲取到一個(gè)測(cè)試公眾賬號(hào)的信息。主要有appId和appsecret兩個(gè)參數(shù),這將唯一標(biāo)示一個(gè)公眾號(hào),并且需要將他們作為參數(shù)獲取用戶的信息。、

2)、配置接口信息
這一步可以參照微信接入說(shuō)明,該頁(yè)提供一個(gè)php的實(shí)例下載,很簡(jiǎn)單基本上修改一下自定義的TOKEN就好了,然后把驗(yàn)證頁(yè)面放到自己的服務(wù)器上。
這里我提供我做的一個(gè)例子:
準(zhǔn)備資源:
域名+空間(我的是sae空間+萬(wàn)網(wǎng)域名)、僅作驗(yàn)證的php文件
域名指向的空間根目錄我創(chuàng)建了一個(gè)wx_sample.php
wx_sample.php
<?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;
}
}
}
?>
然后填寫(xiě)配置信息Token (一定要與上面的wx_sample.php中的token一致)、URL(wx_sample.php的地址)

然后提交就可以了
如果提示失敗,請(qǐng)檢查T(mén)oken與URL【如果是自己的域名和空間,請(qǐng)備案; 百度sae、新浪sae的需要自己申請(qǐng)而且認(rèn)證通過(guò)(就是自己拍一個(gè)手握證件照上傳,很簡(jiǎn)單的 最短2天就o了),這一步必須】
3)配置JS接口安全域名
填這個(gè)域名是一定不要帶protocol的,比如說(shuō) http://www.sagosoft.com/ 這樣是不對(duì)的,這是URL不是域名
域名應(yīng)該是類似 www.sagosoft.com這樣的 【否則在微信js-sdk接入時(shí)會(huì)提示invalid url domain】

4)關(guān)注公眾號(hào)
用戶只有關(guān)注了這個(gè)公眾號(hào)了,才能通過(guò)打開(kāi)有公眾號(hào)信息的鏈接去授權(quán)第三方登錄,并獲取用戶信息的操作。故我們還需要用我們的微信關(guān)注微信號(hào),操作如下:
還是剛剛那個(gè)登錄成功后跳轉(zhuǎn)的頁(yè)面,我們可以看到,該頁(yè)面有一個(gè)二維碼,我們可以通過(guò)掃描該二維碼進(jìn)行關(guān)注,關(guān)注成功在右邊的“用戶列表”會(huì)多一個(gè)用戶的信息。如下圖所示:

5)配置回調(diào)函數(shù)
我們?cè)谖⑿趴蛻舳嗽L問(wèn)第三方網(wǎng)頁(yè)(即我們自己的網(wǎng)頁(yè))的時(shí)候,我們可以通過(guò)微信網(wǎng)頁(yè)授權(quán)機(jī)制,我們不僅要有前面獲取到的appid和appsecret還需要有當(dāng)用戶授權(quán)之后,回調(diào)的域名設(shè)置,即用戶授權(quán)后,頁(yè)面會(huì)跳轉(zhuǎn)到哪里。具體的配置如下:
還是在剛剛的頁(yè)面,有一個(gè)“網(wǎng)頁(yè)授權(quán)獲取用戶基本信息”,點(diǎn)擊后面的修改

填寫(xiě)回調(diào)的域名:
域名是上面配置的根域名,假如你上面 “接口配置信息” 填寫(xiě)的url 為zcr.sinaaappc.com/wx_sample.php,這里只要填寫(xiě)zcr.sinaaappc.com 就可以了。

如果你的網(wǎng)址沒(méi)有被列入過(guò)黑名單,就會(huì)在頂部出現(xiàn)


注意:
1、這里填寫(xiě)的是域名(是一個(gè)字符串),而不是URL,因此請(qǐng)勿加http://等協(xié)議頭;
2、授權(quán)回調(diào)域名配置規(guī)范為全域名,比如需要網(wǎng)頁(yè)授權(quán)的域名為:www.qq.com,配置以后此域名下面的頁(yè)面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無(wú)法進(jìn)行OAuth2.0鑒權(quán)
到這里,我們就完成了公眾號(hào)測(cè)試賬號(hào)的獲取和配置,已經(jīng)用戶關(guān)注微信公眾號(hào)。
4、通過(guò)appid和appsecret獲取我們的access_token
access_token是公眾號(hào)的全局唯一票據(jù),公眾號(hào)調(diào)用各接口時(shí)都需使用access_token。開(kāi)發(fā)者需要進(jìn)行妥善保存。access_token的存儲(chǔ)至少要保留512個(gè)字符空間。access_token的有效期目前為2個(gè)小時(shí),需定時(shí)刷新,重復(fù)獲取將導(dǎo)致上次獲取的access_token失效。
獲取方法:
http請(qǐng)求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
參數(shù)說(shuō)明:

正常情況下,微信會(huì)返回下述JSON數(shù)據(jù)包給公眾號(hào):

錯(cuò)誤時(shí)微信會(huì)返回錯(cuò)誤碼等信息,JSON數(shù)據(jù)包示例如下(該示例為AppID無(wú)效錯(cuò)誤):
例子:
獲取access_token:
返回?cái)?shù)據(jù):
{
"access_token": "qR5UK2vMf5aTHV8e-uB10FZW0caTZm_1kbkUe4OPK2ILVvNaoa7pLzYWqLUAmx6Sjq1E7pKHrVAtuG0_1MPkqmDfOkm2750kaLWNk59DS-iDOpjjxompJtXa3WhbN5FKRWNhADAVAR",
"expires_in": 7200
}
5、通過(guò)access_token群發(fā)短信
在公眾平臺(tái)網(wǎng)站上,為訂閱號(hào)提供了每天一條的群發(fā)權(quán)限,為服務(wù)號(hào)提供每月(自然月)4條的群發(fā)權(quán)限。而對(duì)于某些具備開(kāi)發(fā)能力的公眾號(hào)運(yùn)營(yíng)者,可以通過(guò)高級(jí)群發(fā)接口,實(shí)現(xiàn)更靈活的群發(fā)能力。
請(qǐng)注意:
1、對(duì)于認(rèn)證訂閱號(hào),群發(fā)接口每天可成功調(diào)用1次,此次群發(fā)可選擇發(fā)送給全部用戶或某個(gè)分組;
2、對(duì)于認(rèn)證服務(wù)號(hào)雖然開(kāi)發(fā)者使用高級(jí)群發(fā)接口的每日調(diào)用限制為100次,但是用戶每月只能接收4條,無(wú)論在公眾平臺(tái)網(wǎng)站上,還是使用接口群發(fā),用戶每月只能接收4條群發(fā)消息,多于4條的群發(fā)將對(duì)該用戶發(fā)送失??;
3、具備微信支付權(quán)限的公眾號(hào),在使用群發(fā)接口上傳、群發(fā)圖文消息類型時(shí),可使用<a>標(biāo)簽加入外鏈;
4、開(kāi)發(fā)者可以使用預(yù)覽接口校對(duì)消息樣式和排版,通過(guò)預(yù)覽接口可發(fā)送編輯好的消息給指定用戶校驗(yàn)效果。
1)根據(jù)分組進(jìn)行群發(fā)【訂閱號(hào)與服務(wù)號(hào)認(rèn)證后均可用】
調(diào)用接口:
在body添加如下數(shù)據(jù)(以JSON格式數(shù)據(jù)發(fā)送)——發(fā)送其他格式數(shù)據(jù),只需要改里面參數(shù)信息即可,具體可查看微信官方文檔:
{
"filter":{
"is_to_all":false,
"group_id":2
},
"text":{
"content":"CONTENT"
},
"msgtype":"text"
}
參數(shù)說(shuō)明:

例子:發(fā)送給所有人
url:
發(fā)送的json數(shù)據(jù):發(fā)送給所有人
{
"filter":{
"is_to_all":true
},
"text":{
"content":"CONTENT"
},
"msgtype":"text"
}
返回?cái)?shù)據(jù):
{
"errcode": 0,
"errmsg": "send job submission success",
"msg_id": 1000000003
}
參數(shù)意義:

錯(cuò)誤碼及其以及查詢:
使用postman模擬https請(qǐng)求發(fā)送如下圖所示:

2)根據(jù)OpenID列表群發(fā)【訂閱號(hào)不可用,服務(wù)號(hào)認(rèn)證后可用】
發(fā)送的http請(qǐng)求url:(注意:和上面的不同)
數(shù)據(jù)格式:
其中OPENID1和OPENID2是我們要發(fā)送的微信用戶openId(用戶的唯一標(biāo)示)。
例子:
發(fā)送"oF3PcsnsrMiJzEwalZZbAfWQpxCI","oF3PcshH1CUIhR_WYau6swUiPzlw" 兩個(gè)用戶。
內(nèi)容為:hello from boxer.<a href='www.baidu.com'>歡迎來(lái)到百度</a>
url:
json數(shù)據(jù):
{
"touser":[
"oF3PcsnsrMiJzEwalZZbAfWQpxCI",
"oF3PcshH1CUIhR_WYau6swUiPzlw"
],
"msgtype": "text",
"text": { "content": "hello from boxer.<a }
}
返回?cái)?shù)據(jù):
{
"errcode": 0,
"errmsg": "send job submission success",
"msg_id": 3147483654
}
使用postman模擬發(fā)送請(qǐng)求如下:

微信號(hào)接收到的內(nèi)容:

致謝:感謝您的閱讀!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
thinkPHP分組后模板無(wú)法加載問(wèn)題解決方法
這篇文章主要介紹了thinkPHP分組后模板無(wú)法加載問(wèn)題解決方法,分析了thinkPHP分組后模板無(wú)法加載的原因與相應(yīng)的設(shè)置方法,需要的朋友可以參考下2016-07-07
thinkphp 中的volist標(biāo)簽在ajax操作中的特殊性(推薦)
在一個(gè)ThinkPHP的復(fù)雜頁(yè)面(包含volist)中實(shí)現(xiàn)volist標(biāo)簽顯示Jquery查詢結(jié)果的返回。這篇文章給大家介紹了thinkphp 中的volist標(biāo)簽在ajax操作中的特殊性(推薦),需要的朋友參考下吧2018-01-01
tp5.1 實(shí)現(xiàn)setInc字段自動(dòng)加1
今天小編就為大家分享一篇tp5.1 實(shí)現(xiàn)setInc字段自動(dòng)加1示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
PHP中如何使用session實(shí)現(xiàn)保存用戶登錄信息
這篇文章主要給大家介紹在php中是如何使用session實(shí)現(xiàn)保存用戶登錄信息的,涉及到php session 用戶登錄等一些知識(shí)點(diǎn),使用session保存用戶登錄信息要比cookie安全很多。感興趣的朋友一起學(xué)習(xí)吧2015-10-10
PHP實(shí)現(xiàn)微信支付(jsapi支付)流程步驟詳解
這篇文章主要介紹了PHP實(shí)現(xiàn)微信支付(jsapi支付)流程步驟詳解,需要的朋友可以參考下2018-03-03
使用symfony命令創(chuàng)建項(xiàng)目的方法
這篇文章主要介紹了使用symfony命令創(chuàng)建項(xiàng)目的方法,結(jié)合實(shí)例形式分析了Symfony命令的使用方法與項(xiàng)目創(chuàng)建的相關(guān)技巧,需要的朋友可以參考下2016-03-03
PHP對(duì)接微信公眾平臺(tái)消息接口開(kāi)發(fā)流程教程
這篇文章主要介紹了PHP對(duì)接微信公眾平臺(tái)消息接口開(kāi)發(fā)流程,如何使用PHP版接口操作公眾平臺(tái)消息,需要的朋友可以參考下2014-03-03

