欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php實現微信小程序訂閱消息推送(access_token獲取緩存刷新)

 更新時間:2023年08月06日 11:01:23   作者:TANKING  
這篇文章主要為大家介紹了php實現微信小程序訂閱消息推送包含access_token獲取緩存刷新示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

摘要

微信小程序的訂閱消息功能具有多個優(yōu)點,可以為開發(fā)者和用戶帶來便利和更好的體驗。

以下是一些主要的優(yōu)點:

個性化消息推送: 訂閱消息允許開發(fā)者向用戶發(fā)送個性化的消息內容,根據用戶的偏好和行為進行定制化推送,從而提供更有價值的信息。

降低打擾度: 相對于模板消息,訂閱消息更加注重用戶隱私和興趣,用戶可以自主選擇訂閱自己感興趣的內容,降低了不必要的打擾。

長期溝通: 訂閱消息不受時間限制,允許開發(fā)者與用戶建立長期的溝通渠道,向他們傳遞重要信息、更新和促銷等。

用戶參與度提升: 個性化的消息內容和定制化的推送可以提高用戶的參與度和互動性,從而增強用戶對小程序的粘性和忠誠度。

多行業(yè)適用: 訂閱消息適用于多種行業(yè),包括新聞資訊、社交、電商、健康等,開發(fā)者可以根據自己的業(yè)務需求進行靈活應用。

統計和分析: 微信提供了訂閱消息的統計數據,開發(fā)者可以了解消息的送達率、點擊率等數據,有助于優(yōu)化消息內容和推送策略。

用戶控制權: 用戶有權隨時取消訂閱,保留了用戶的自主權,不會讓用戶感到被過度干擾。

簡化用戶操作: 用戶無需頻繁打開小程序,即可獲取相關信息,提供了更加便捷的獲取方式。

如何發(fā)送訂閱消息

微信提供了完善的開發(fā)文檔,通過調用接口可以向指定的openid進行發(fā)送訂閱消息:

代碼

sendDyxx.php

<?php
namespace MyWeChat;
class WeChatApi
{
    // 刷新access_token
    private static function refreshAccessToken($appid, $appsecret)
    {
        $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret";
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        $response = curl_exec($ch);
        curl_close($ch);
        $data = json_decode($response, true);
        if (isset($data['access_token'])) {
            return $data['access_token'];
        } else {
            return false;
        }
    }
    // 獲取新的access_token
    private static function getAccessTokenFromCache($tokenFile)
    {
        if (file_exists($tokenFile)) {
            $tokenData = include($tokenFile);
            if ($tokenData && is_array($tokenData) && isset($tokenData['access_token']) && isset($tokenData['expires_at'])) {
                return $tokenData;
            }
        }
    }
    // 更新access_token緩存文件
    private static function updateAccessTokenCache($tokenFile, $access_token, $expires_in)
    {
        $expires_at = time() + $expires_in - 60;
        $tokenData = "<?php\nreturn array('access_token' => '$access_token', 'expires_at' => $expires_at);\n";
        file_put_contents($tokenFile, $tokenData);
    }
    // 發(fā)送訂閱消息
    public static function sendMessageWithAccessToken($appid, $appsecret, $template_id, $openid, $data_template)
    {
        $TOKEN_FILE = 'access_token.php';
        $tokenData = self::getAccessTokenFromCache($TOKEN_FILE);
        if ($tokenData && $tokenData['expires_at'] > time()) {
            $access_token = $tokenData['access_token'];
        } else {
            $access_token = self::refreshAccessToken($appid, $appsecret);
            if ($access_token) {
                self::updateAccessTokenCache($TOKEN_FILE, $access_token, 7200);
            } else {
                echo "Access_Token刷新失敗\n";
                return;
            }
        }
        // 發(fā)送訂閱消息的接口
        $url = "https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token=$access_token";
        // 需要發(fā)送的消息體
        $message_data = [
            "touser" => $openid,
            "template_id" => $template_id,
            "page" => "pages/read/read?aid=360282",
            "miniprogram_state" => "formal",
            "lang" => "zh_CN",
            "data" => $data_template
        ];
        // 初始化cURL
        $ch = curl_init();
        // 配置cURL
        curl_setopt_array($ch, [
            CURLOPT_URL => $url,
            CURLOPT_POST => 1,
            CURLOPT_POSTFIELDS => json_encode($message_data),
            CURLOPT_RETURNTRANSFER => true,
            CURLOPT_HTTPHEADER => ['Content-Type: application/json']
        ]);
        // 執(zhí)行cURL
        $response = curl_exec($ch);
        // 判斷發(fā)送結果
        if (curl_errno($ch)) {
            // 失敗
            echo '執(zhí)行失敗: ' . curl_error($ch);
        } else {
            // 成功
            echo '執(zhí)行成功: ' . $response;
        }
        // 關閉cURL
        curl_close($ch);
    }
}
// 小程序配置(APPID、APPSECRET)
$APPID = 'xxx'; // 小程序APPID
$APPSECRET = 'xxx'; // 小程序APPSECRET
// 小程序訂閱消息配置(模板id、openid、模板字段)
$template_id = "xxx"; // 模板id
$openid = "o9usm0bhIkcbAyxM0RzDXi9tjHhM"; // 接收消息的openid
// 模板id對應的模板字段
$data_template = [
    "character_string1" => ["value" => "2023-08-03"],
    "thing4" => ["value" => "開發(fā)測試"]
];
// 執(zhí)行靜態(tài)方法
WeChatApi::sendMessageWithAccessToken($APPID, $APPSECRET, $template_id, $openid, $data_template);
?>

以上代碼的優(yōu)點顯而易見,易擴展,易維護,易移植!而且是一個php文件解決了access_token的獲取、緩存、刷新、更新緩存、配置、發(fā)送!

access_token的有效期是2小時,以上代碼直接獲取到access_token緩存到本地,然后每次請求直接讀取本地的緩存,高效、快速、安全、效率!

技術拓展

如果你有大量的openid,那么你需要結合異步消息隊列的技術來實現群發(fā),例如Redis異步消息隊列,定時任務等在后臺執(zhí)行一個任務去實現群發(fā),就可以實現批量openid的推送,可以研究一下!

以上就是php實現微信小程序訂閱消息推送(access_token獲取緩存刷新)的詳細內容,更多關于php微信小程序訂閱消息推送的資料請關注腳本之家其它相關文章!

相關文章

最新評論