濮阳杆衣贸易有限公司

主頁 > 知識庫 > 微信公眾平臺開發(fā)——群發(fā)信息

微信公眾平臺開發(fā)——群發(fā)信息

熱門標簽:地圖標注審核工作怎么樣注冊 鄭州中國移動400電話申請 地圖標注植物名稱 無錫電銷機器人銷售 招聘信息 福建ai電銷機器人加盟公司 南召400電話辦理資費 揭陽外呼系統(tǒng)公司 熱血傳奇沃瑪森林地圖標注 去哪里辦卡

1、目的

  完成在微信公眾號中群發(fā)消息。這里只是完成簡單的文字發(fā)送。也可以發(fā)送語音圖片等,只是發(fā)送數(shù)據(jù)格式不同而已,下面有鏈接,可以查詢數(shù)據(jù)類型的數(shù)據(jù)發(fā)送格式。

2、群發(fā)短信的流程

  1. 獲取測試公眾賬號(有賬號的可以不用測試賬號,不過正式的賬號限制比較多)
  2. 用戶關注上面的公眾賬號
  3. 通過appid和appsecret獲取我們的access_token
  4. 通過access_token群發(fā)短信

3、獲取測試公眾賬號 + 關注公眾號

1)、公眾測試賬號獲取

  訪問上面的連接,選擇“接口測試號申請”獲得直接打開http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfot=sandbox/index通過微信客戶端掃碼登錄即可登錄。

  登錄完即可獲取到一個測試公眾賬號的信息。主要有appId和appsecret兩個參數(shù),這將唯一標示一個公眾號,并且需要將他們作為參數(shù)獲取用戶的信息。、

2)、配置接口信息

這一步可以參照微信接入說明 ,該頁提供一個php的實例下載,很簡單基本上修改一下自定義的TOKEN就好了,然后把驗證頁面放到自己的服務器上。

       這里我提供我做的一個例子:

        準備資源:

        域名+空間(我的是sae空間+萬網(wǎng)域名)、僅作驗證的php文件

        域名指向的空間根目錄我創(chuàng)建了一個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;
  }
 }
}

?>

 然后填寫配置信息Token (一定要與上面的wx_sample.php中的token一致)、URL(wx_sample.php的地址)

 然后提交就可以了

  如果提示失敗,請檢查Token與URL【如果是自己的域名和空間,請備案; 百度sae、新浪sae的需要自己申請而且認證通過(就是自己拍一個手握證件照上傳,很簡單的 最短2天就o了),這一步必須】

 3)配置JS接口安全域名

  填這個域名是一定不要帶protocol的,比如說 http://www.sagosoft.com/   這樣是不對的,這是URL不是域名

  域名應該是類似 www.sagosoft.com這樣的 【否則在微信js-sdk接入時會提示invalid url domain】

4)關注公眾號

  用戶只有關注了這個公眾號了,才能通過打開有公眾號信息的鏈接去授權第三方登錄,并獲取用戶信息的操作。故我們還需要用我們的微信關注微信號,操作如下:

  還是剛剛那個登錄成功后跳轉(zhuǎn)的頁面,我們可以看到,該頁面有一個二維碼,我們可以通過掃描該二維碼進行關注,關注成功在右邊的“用戶列表”會多一個用戶的信息。如下圖所示:

5)配置回調(diào)函數(shù)

我們在微信客戶端訪問第三方網(wǎng)頁(即我們自己的網(wǎng)頁)的時候,我們可以通過微信網(wǎng)頁授權機制,我們不僅要有前面獲取到的appid和appsecret還需要有當用戶授權之后,回調(diào)的域名設置,即用戶授權后,頁面會跳轉(zhuǎn)到哪里。具體的配置如下:

  還是在剛剛的頁面,有一個“網(wǎng)頁授權獲取用戶基本信息”,點擊后面的修改

填寫回調(diào)的域名:

  域名是上面配置的根域名,假如你上面 “接口配置信息” 填寫的url 為zcr.sinaaappc.com/wx_sample.php,這里只要填寫zcr.sinaaappc.com  就可以了。

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

注意:

1、這里填寫的是域名(是一個字符串),而不是URL,因此請勿加http://等協(xié)議頭;
2、授權回調(diào)域名配置規(guī)范為全域名,比如需要網(wǎng)頁授權的域名為:www.qq.com,配置以后此域名下面的頁面http://www.qq.com/music.html 、 http://www.qq.com/login.html 都可以進行OAuth2.0鑒權。但http://pay.qq.com 、 http://music.qq.com 、 http://qq.com無法進行OAuth2.0鑒權

  到這里,我們就完成了公眾號測試賬號的獲取和配置,已經(jīng)用戶關注微信公眾號。

4、通過appid和appsecret獲取我們的access_token

  access_token是公眾號的全局唯一票據(jù),公眾號調(diào)用各接口時都需使用access_token。開發(fā)者需要進行妥善保存。access_token的存儲至少要保留512個字符空間。access_token的有效期目前為2個小時,需定時刷新,重復獲取將導致上次獲取的access_token失效。

獲取方法:

http請求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credentialappid=APPIDsecret=APPSECRET

參數(shù)說明

參數(shù) 是否必須 說明
grant_type 獲取access_token填寫client_credential
appid 第三方用戶唯一憑證
secret 第三方用戶唯一憑證密鑰,即appsecret

返回說明

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

{"access_token":"ACCESS_TOKEN","expires_in":7200} 

參數(shù) 說明
access_token 獲取到的憑證
expires_in 憑證有效時間,單位:秒

錯誤時微信會返回錯誤碼等信息,JSON數(shù)據(jù)包示例如下(該示例為AppID無效錯誤):

{"errcode":40013,"errmsg":"invalid appid"} 

例子:

獲取access_token:

https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credentialappid=wx41cb8dbd827a16e9secret=d4624c36b6795d1d99dcf0547af5443d

返回數(shù)據(jù):

{
 "access_token": "qR5UK2vMf5aTHV8e-uB10FZW0caTZm_1kbkUe4OPK2ILVvNaoa7pLzYWqLUAmx6Sjq1E7pKHrVAtuG0_1MPkqmDfOkm2750kaLWNk59DS-iDOpjjxompJtXa3WhbN5FKRWNhADAVAR",
 "expires_in": 7200
}

5、通過access_token群發(fā)短信

  在公眾平臺網(wǎng)站上,為訂閱號提供了每天一條的群發(fā)權限,為服務號提供每月(自然月)4條的群發(fā)權限。而對于某些具備開發(fā)能力的公眾號運營者,可以通過高級群發(fā)接口,實現(xiàn)更靈活的群發(fā)能力。

請注意:

1、對于認證訂閱號,群發(fā)接口每天可成功調(diào)用1次,此次群發(fā)可選擇發(fā)送給全部用戶或某個分組;
2、對于認證服務號雖然開發(fā)者使用高級群發(fā)接口的每日調(diào)用限制為100次,但是用戶每月只能接收4條,無論在公眾平臺網(wǎng)站上,還是使用接口群發(fā),用戶每月只能接收4條群發(fā)消息,多于4條的群發(fā)將對該用戶發(fā)送失??;
3、具備微信支付權限的公眾號,在使用群發(fā)接口上傳、群發(fā)圖文消息類型時,可使用a>標簽加入外鏈;
4、開發(fā)者可以使用預覽接口校對消息樣式和排版,通過預覽接口可發(fā)送編輯好的消息給指定用戶校驗效果。
 

 1)根據(jù)分組進行群發(fā)【訂閱號與服務號認證后均可用】

調(diào)用接口:

http請求方式: POST
https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_token=ACCESS_TOKEN
 在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ù)說明:

參數(shù) 是否必須 說明
filter 用于設定圖文消息的接收者
is_to_all 用于設定是否向全部用戶發(fā)送,值為true或false,選擇true該消息群發(fā)給所有用戶,選擇false可根據(jù)group_id發(fā)送給指定群組的用戶
group_id 群發(fā)到的分組的group_id,參加用戶管理中用戶分組接口,若is_to_all值為true,可不填寫group_id
mpnews 用于設定即將發(fā)送的圖文消息
media_id 用于群發(fā)的消息的media_id
msgtype 群發(fā)的消息類型,圖文消息為mpnews,文本消息為text,語音為voice,音樂為music,圖片為image,視頻為video,卡券為wxcard
title 消息的標題
description 消息的描述
thumb_media_id 視頻縮略圖的媒體ID

例子:發(fā)送給所有人

url:

https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_token=KBoNONaJZ4-KhafQVJoQ6VBX0F-bls7nAsJBn8Fy7GLwav4Be1lRJcob1RHH6wW35IxxFwkJnZfnc-On9EQITg3oxEWUw7O2YyVW9naDknu6PQX9fnSmQcr8ojTK8Ug-HDTcAAABXN

發(fā)送的json數(shù)據(jù):發(fā)送給所有人

{
 "filter":{
  "is_to_all":true
 },
 "text":{
  "content":"CONTENT"
 },
 "msgtype":"text"
}
 

返回數(shù)據(jù):

{
 "errcode": 0,
 "errmsg": "send job submission success",
 "msg_id": 1000000003
}

參數(shù)意義:

 

參數(shù) 說明
type 媒體文件類型,分別有圖片(image)、語音(voice)、視頻(video)和縮略圖(thumb),圖文消息為news
errcode 錯誤碼
errmsg 錯誤信息
msg_id 消息發(fā)送任務的ID
msg_data_id 消息的數(shù)據(jù)ID,該字段只有在群發(fā)圖文消息時,才會出現(xiàn)??梢杂糜谠趫D文分析數(shù)據(jù)接口中,獲取到對應的圖文消息的數(shù)據(jù),是圖文分析數(shù)據(jù)接口中的msgid字段中的前半部分,詳見圖文分析數(shù)據(jù)接口中的msgid字段的介紹。

錯誤碼及其以及查詢:

  全局錯誤碼解析

使用postman模擬https請求發(fā)送如下圖所示:

2)根據(jù)OpenID列表群發(fā)【訂閱號不可用,服務號認證后可用】

發(fā)送的http請求url:(注意:和上面的不同)

http請求方式: POST
https://api.weixin.qq.com/cgi-bin/message/mass/send?access_token=ACCESS_TOKEN

數(shù)據(jù)格式:

{
 "touser":[
 "OPENID1",
 "OPENID2"
 ],
 "msgtype": "text",
 "text": { "content": "hello from boxer."}
}
 

其中 OPENID1和OPENID2是我們要發(fā)送的微信用戶openId(用戶的唯一標示)。

例子:

發(fā)送"oF3PcsnsrMiJzEwalZZbAfWQpxCI","oF3PcshH1CUIhR_WYau6swUiPzlw" 兩個用戶。

內(nèi)容為:hello from boxer.a href=‘www.baidu.com‘>歡迎來到百度/a>

url:

https://api.weixin.qq.com/cgi-bin/message/mass/send?access_token=wRyTbnsiu18ssEhMPLf4bDfeT-Bt6e6tgR4CQGVLBipRcyJPkdAKPYfM6-qkKuHUN8uRKJh6Xvm0OuAdFgqOo8Ru8hoDxl-cGc9bh-ezJb2ZUcJSnQk2s416zI8kbEOfOGYdAFARJB
 

json數(shù)據(jù):

{
 "touser":[
 "oF3PcsnsrMiJzEwalZZbAfWQpxCI",
 "oF3PcshH1CUIhR_WYau6swUiPzlw"
 ],
 "msgtype": "text",
 "text": { "content": "hello from boxer.a href=‘http://www.seewoedu.com/‘>歡迎希沃學院/a>"}
}
 

返回數(shù)據(jù):

{
 "errcode": 0,
 "errmsg": "send job submission success",
 "msg_id": 3147483654
}

使用postman模擬發(fā)送請求如下:

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

相關微信開發(fā):

微信開放平臺開發(fā)——網(wǎng)頁微信掃碼登錄(OAuth2.0)

微信公眾平臺開發(fā)——微信授權登錄(OAuth2.0)

 致謝:感謝您的閱讀!

您可能感興趣的文章:
  • php微信公眾平臺開發(fā)之微信群發(fā)信息
  • php微信高級接口群發(fā) 多客服
  • C#微信公眾平臺開發(fā)之高級群發(fā)接口
  • asp.net微信開發(fā)(高級群發(fā)圖文)
  • asp.net微信開發(fā)(高級群發(fā)文本)
  • php實現(xiàn)微信公眾號無限群發(fā)
  • C#實現(xiàn)微信公眾號群發(fā)消息(解決一天只能發(fā)一次的限制)實例分享
  • php微信公眾號開發(fā)(4)php實現(xiàn)自定義關鍵字回復
  • php微信公眾號開發(fā)(3)php實現(xiàn)簡單微信文本通訊
  • 微信公眾號模板消息群發(fā)php代碼示例

標簽:黔南 桂林 東莞 南昌 宣城 景德鎮(zhèn) 文山 鹽城

巨人網(wǎng)絡通訊聲明:本文標題《微信公眾平臺開發(fā)——群發(fā)信息》,本文關鍵詞  微信,公眾,平臺,開發(fā),群發(fā),;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《微信公眾平臺開發(fā)——群發(fā)信息》相關的同類信息!
  • 本頁收集關于微信公眾平臺開發(fā)——群發(fā)信息的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    楚雄市| 宣城市| 台中市| 高邑县| 景宁| 景东| 车致| 宝鸡市| 盖州市| 中宁县| 宝丰县| 黄浦区| 微博| 扶绥县| 乌兰县| 南召县| 曲周县| 屏南县| 巨野县| 临夏县| 图木舒克市| 威远县| 盐津县| 青海省| 岚皋县| 博野县| 酉阳| 平谷区| 贵州省| 东平县| 南陵县| 田林县| 勃利县| 乌兰察布市| 石泉县| 隆安县| 凤山市| 海阳市| 芦山县| 奎屯市| 宁河县|