❶ 微信群發器是怎麼開發的
通過介面協議完成的,這些協議就是微信的api,或者hook微信做到的。gitee和github上有蠻多,可以參考一下。
❷ 微信小程序 實現模板消息群發、發送給指定用戶
最近在做一款拼課類小程序,大概需求就是分享課程頁面給好友,好友參與達到一定數量後則拼課成功。 按理說很平常的需求,微信公眾號里邊應該很容易實現,但是想在小程序里邊實現這么個功能卻有點蛋疼了。 為什麼小程序實現起來比較費勁呢,那就要說下小程序發送模板消息的機制了,先看文檔怎麼說: 劃重點, 本人 、 交互 ,也就是說這個模板消息,必須由用戶手動來觸發,你想後台定時給用戶推個消息,洗洗睡吧你。 再來看下面: 這個重點你們自己劃吧,發模板消息必須滿足這兩種情況中的一種,支付就不說了,用戶付款後可以推送幾條消息,重點是這個 表單提交 。 意思就是我想給用戶發個模板消息,第一要搞個表單,第二要讓用戶來提交這個表單(獲取formId),而且這個模板消息還只能發給提交表單的用戶本人,你想發給別的用戶,呵呵。好了,說多了都是氣,既然這樣設計,也是有一定道理,但是道理都是講給守規矩的人聽的,至於不守規矩的,喂!說的就是你。 通過上面的分析我們知道,想發送一個基本的模板消息需要以下步驟: 模板消息介面 POST https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=ACCESS_TOKEN 有這么幾個參數 :前面扯了一堆概念,下面我們來把這個功能具體的實現一遍吧,我這里後台用的是php laravel,原理都一樣。 我這只寫一個例子,一看就明白 有些時候用戶操作頻繁,可能會導致伺服器收到大量請求,所以可以優化下,把formId先存到一個全局變數里邊(數組),當達到一定數量後統一發給後台來保存。這塊可以靈活運用。 服務端的實現也就兩個功能, 收集 和 發送 。 假設我們現在有這么一個類FormIdCollection,可以收集(save)和獲取(get)某個openid的formId,那我們給前台暴露的api只需要簡單的調用下就可以了,至於發消息,也只需要get一個formId,即可。 下面是FormIdCollection類的一個具體實現,基於laravel(說實話,挺好用的),另外引入了一個微信開發包 overtrue/wechat (這里主要是用來發模板消息、有點大材小用了), https://www.easywechat.com/ 我已經封裝了一個laravel擴展包,感興趣的朋友可以上github上看下 https://github.com/laravuel/laravel-wfc 。 至於非框架的php實現,小夥伴可以幫忙弄下。❸ 微信開發php怎麼實現,一個關鍵字回復多個消息
https://mp.weixin.qq.com/wiki
當用戶發送消息給公眾號時(或某些特定的用戶操作引發的事件推送時),會產生一個POST請求,開發者可以在響應包(Get)中返回特定XML結構,來對該消息進行響應(現支持回復文本、圖片、圖文、語音、視頻、音樂)。嚴格來說,發送被動響應消息其實並不是一種介面,而是對微信伺服器發過來消息的一次回復。
對該消息進行回復時,你能夠獲取用戶的openid,通過以下介面
「客服消息
當用戶和公眾號產生特定動作的交互時(具體動作列表請見下方說明),微信將會把消息數據推送給開發者,開發者可以在一段時間內(目前修改為48小時)調用客服介面,通過POST一個JSON數據包來發送消息給普通用戶。此介面主要用於客服等有人工消息處理環節的功能,方便開發者為用戶提供更加優質的服務。」
你可以針對一個用戶發送多條信息
❹ PHP寮鍙戜腑濡備綍瀹炵幇涓庡井淇℃帴鍙e規帴
php鐢╟url璁塊棶寰淇℃帴鍙o紝get鎴栬卲ost鏂瑰紡錛屾槸鍚﹂渶瑕佷紶鍙傦紝浼犱粈涔堝弬鏁幫紝浠涔堟牸寮忋傚井淇℃枃妗i兘鏈夎存槑錛岃繑鍥炴暟鎹鍚庣敤php澶勭悊鎴愭暟緇勮繘琛屾搷浣滃嵆鍙
❺ php網頁開發微信分享成功後的回調函數怎麼寫
1、簽名:
url: 需要根據不同的頁面動態獲取,url不能進行encodeURIComponent,否則驗簽會失敗 url不能包括微信添加的#後邊的部分,所以應該處理為:window.location.href.split('#')[0] 簽名用的url必須是調用JS介面頁面的完整URL。
nonceStr、timestamp:應該動態生成,而不能hardcode 簽名用的noncestr和timestamp必須與wx.config中的nonceStr和timestamp相同
為安全考慮,簽名必須在後台進行,其他調用js在前台進行。
2、ticket和accesstoken:
accesstoken:同調用微信其他介面的accesstoken,必須全局緩存,以免影響其他業務,即是說:微信所有業務應該用同一個accesstoken去調用微信介面,而不能自己刷新accesstoken。
ticket:同accesstoken一樣,必須全局緩存,方式很多,可以放到資料庫,或者放到緩存。目前ticket的有效時間為2小時,所以2小時內ticket未過期時,不能重復獲取,否則可能導致ticket獲取次數超過限額,導致sign失敗。
3、注意代碼執行順序
首先應該獲取簽名,簽名獲取後在調用wx.config方法,然後再執行wx.ready、wx.error方法。
4、其他
每個頁面載入完成後都應該重新從後台獲取簽名信息,避免簽名失敗
具體開發步驟詳見官方文檔
5、官方常見問題及處理方法:
調用config 介面的時候傳入參數 debug: true 可以開啟debug模式,頁面會alert出錯誤信息。
❻ 自己用thinkphp做微信介面類文件,遇一個問題,GET獲取到的token,如何將這個變數傳遞到實例化的類裡面
classIndexActionextendsAction{
publicfunctionindex(){
$token=D("wx_token")->field("add_ip",true)->select();
foreach($tokenas$key=>$v){
if($v['expire_time']-300<time()){
$url="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$v['appid']}&secret={$v['secret']}";
$res=file_get_contents($url,false);
$this->getAccessToken($v['id'],$res);
}else{
$date=date("Y-m-dH:i:s");
echo"{$date}_____noexpire ";
}
}
}
privatefunctiongetAccessToken($token,$res){
$sign=false;
$json=json_decode($res);
$data['id']=$token;
$data['access_token']=$json->access_token;
$data['expire_time']=time()+7200;
$data['add_time']=time();
$data['add_ip']='127.0.0.1';
$db=D("wx_token");
$db->startTrans();
if($db->save($data)){
$db->commit();
$sign=true;
}else{
$db->rollback();
$sign=false;
}
return$sign;
}
}
再創建個數據表,保存就好了,整個定時任務,定時去獲取比較好。