ホームページ >WeChat アプレット >WeChatの開発 >WeChat パブリック プラットフォーム開発 access_token、ログ

WeChat パブリック プラットフォーム開発 access_token、ログ

高洛峰
高洛峰オリジナル
2017-03-01 10:09:541590ブラウズ

1. access_token

1) Web ページ認証 access_token と通常の access_token の 2 つの access_token

1. ユーザーが公式アカウントを認証した後、公式アカウントは Web ページ認証を取得できます。インターフェイス呼び出し資格情報 (Web ページ承認 access_token)。Web ページ承認 access_token を使用して、基本的なユーザー情報の取得など、承認後のインターフェイス呼び出しを実行できます。


2. 他の WeChat インターフェースの場合は、基本サポートの「Get access_token」インターフェースを通じて通常の access_token 呼び出しを取得する必要があります。 access_token は公式アカウントのグローバルに固有のチケットです。access_token の有効期間は現在 2 時間であり、定期的に更新する必要があります。取得を繰り返すと、最後の access_token が無効になります。

2) access_token をそれぞれ取得します

1. Web ページ認証の場合: クリックして Web ページ認証を表示し、ユーザーの基本情報ドキュメントを表示すると、

Web ページ認証 access_token が取得されていることがわかります。コードと交換され、このコードは WeChat を通じて取得されます。 承認されたリンクから取得され、ドキュメント内の要求に従って取得されます。 具体的なリンク アドレスとパラメータについては、ドキュメントを参照してください。

/**
     * 创建一个需要通过微信的OAuth2.0认证的服务url
     * @param $url 服务号需要认证访问的url
     * @param $scope string snsapi_userinfo | snsapi_base
     *      snsapi_userinfo 可以用来获取用户信息
     *      snsapi_base 可以用来获取openid
     * @param string $state 自定义状态值
     *      此处约定为from_weixin代表是从微信认证过来,一般无需轻易变化
     * @return string 返回认证url地址
     */
    public function createAuthUrl($url, $scope = 'snsapi_base', $state = 'from_weixin')
    {
        $url = strval($url);
        $authUrl = 'https://open.weixin.qq.com/connect/oauth2/authorize';
        /**
         * 此处有大坑,请不要打乱param的顺序
         * 否则微信认证界面会出现白屏
         */
        $param = array(
                'appid' => $this->appId,
                'redirect_uri' => urlencode($url),
                'response_type' => 'code',
                'scope' => $scope,
                'state' => $state
        );
    
        $seg = array();
        foreach ($param as $k => $v) {
            $seg[] = "{$k}={$v}";
        }
        return $authUrl . '?' . join('&', $seg) . '#wechat_redirect';
    }

2. 通常: クリックすると、3 つのパラメーターを通じて取得されるアクセス トークン ドキュメントが表示されます。

ここで注意する必要があるのは、取得したトークンは時間に依存するため、MongoDB に保存します。まず、タイムアウトしたかどうかをデータベースから比較します。タイムアウトしていない場合は、直接比較します。データベースから取得して不要なリクエストを削減します。

2. プッシュログ

WeChat とのやり取り中に、多くのログ情報が生成され、開発中にこれらのログを分析する必要があることがよくあります。ここではログを MongoDB に保存します。 MongoDB の便利な点は、明確に定義されたフィールド名を必要とする MySQL とは異なり、あらゆる構造のデータをドキュメントに配置できることです。私はデバッグ時にさまざまな構造をドキュメントに配置することがよくあります。

先ほどのURL(サーバーアドレス)であるWeChatの入り口ページですが、ここでログを保存するロジックが行われます。ロジックには、フォロー時のメッセージのプッシュ、フォローする QR コードのスキャン、メニューをクリックしてイベントを生成する、メニューのハイパーリンクをクリックするなどが含まれます。

ログの構造は次のとおりです:

1. コードには署名検証ロジックが含まれています

2. 以下の getRawMsg メソッドである file_get_contents('php://input') を通じてリクエスト データを取得します。

3. プッシュログはMongoDBに直接挿入されます

4. 受信したリクエスト情報は以下のparseMsgメソッドです

5. handleEventMsgは様々な状況を処理します

/**
     * 微信公众号入口
     */
    public function actionPortal()
    {
        $weixin = new Weixin();
        //签名验证逻辑
//         if($weixin->checkSignature()){
//             echo $_GET['echostr'];
//         }
//         exit;
        //读取原始请求数据
        $msg = $weixin->getRawMsg();
        
        //推送日志
        $pushlog = new WeixinPushLog();
        $pushlog->logWeixinPush($msg);
        
        $msgObj = $weixin->parseMsg($msg);
        if ($msgObj === false || !is_object($msgObj)) {
            exit;
        }
        switch ($msgObj->MsgType) {
            case 'event' : //接收事件消息
                $this->handleEventMsg($msgObj);
                break;
            default :
                //todo
                break;
        }
    }

6.メッセージをプッシュしたい場合は、die メソッドを追加する必要があります

7. 次のコードでは、2 つのイベント状況のみがリストされています。1 つはサブスクリプションで、もう 1 つはクリック イベントです

8。createRawTuWenMsg は XML をスプライシングしています。クリックしてテンプレート メッセージを表示します。インターフェース。

public function getRawMsg()
    {
        return file_get_contents('php://input');
    }

    /**
     * 解析接收到的消息
     * @param string $msg 消息体
     * @return bool|SimpleXMLElement
     */
    public function parseMsg($msg = '')
    {
        if (!$msg || empty($msg)) {
            return false;
        }
        $msgObj = simplexml_load_string($msg, 'SimpleXMLElement', LIBXML_NOCDATA);
        if ($msgObj === false || !($msgObj instanceof \SimpleXMLElement)) {
            return false;
        }
        return $msgObj;
    }

private function handleEventMsg($msgObj)
    {
        $weixin = new Weixin();
        $openId = $msgObj->FromUserName;
        $fromUserName = $msgObj->ToUserName;
        //未关注,关注后推送
        if ($msgObj->Event == 'subscribe') {
            $pushData['PicUrl'] = 'http://mmbiz.qpic.cn/';
            $pushData['Title'] = '基因检测,带你一起探索生命的奥妙 ';
            $pushData['Description'] = '为什么不同人在身高、体重、肤色和形状上长得不一样?但是往往又和自己的父母相似?';
            $pushData['Url'] = 'http://mp.weixin.qq.com';
            $msg = $weixin->createRawTuWenMsg($fromUserName, $openId, array($pushData));

            die($msg);
        }elseif($msgObj->Event == 'CLICK'){
            //die($msg);
        }
    }
デモのダウンロード:

github アドレス: https://github.com/pwstrick/weixin_demo

CSDN アドレス: http://download.csdn.net/detail/loneleaf1/9045731

WeChat パブリック プラットフォーム開発の access_token とログに関連するその他の記事については、PHP 中国語 Web サイトに注目してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。