微信公众平台开发教程补充:多图文,订阅通知,网页授权,稳定版Access Token,用户信息

一、多图文

多图文已经在消息回复无法回复,在客服消息中也无法发送。

唯一保留的地方是在自定义菜单的click消息中回复时可以正常显示。

            case "CLICK":
                switch ($object->EventKey)
                {
                    case "TEXT":
                        $content = "微笑:/::)\n乒乓:/:oo\n中国:".$this->bytes_to_emoji(0x1F1E8).$this->bytes_to_emoji(0x1F1F3)."\n仙人掌:".$this->bytes_to_emoji(0x1F335);
                        break;
                    case "SINGLENEWS":
                        $content = array();
                        $content[] = array("Title"=>"单图文标题",  "Description"=>"单图文内容", "PicUrl"=>"http://g.hiphotos.bdimg.com/wisegame/pic/item/18cb0a46f21fbe090d338acc6a600c338644adfd.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958");
                        break;
                    case "MULTINEWS": 
                        $content = array();
                        $content[] = array("Title"=>"多图文1标题", "Description"=>"", "PicUrl"=>"http://cdn4.zmketang.com/image/jti0z8q0_3ilxrukpliap5c92f8e17107f.png", "Url" =>"http://m.cnblogs.com/?u=txw1958");
                        $content[] = array("Title"=>"第8套广播体操", "Description"=>"", "PicUrl"=>"http://d.hiphotos.bdimg.com/wisegame/pic/item/f3529822720e0cf3ac9f1ada0846f21fbe09aaa3.jpg", "Url" =>"http://v.qq.com/iframe/player.html?vid=a0189d62cuc&auto=1");
                        $content[] = array("Title"=>"第9套广播体操", "Description"=>"", "PicUrl"=>"http://g.hiphotos.bdimg.com/wisegame/pic/item/18cb0a46f21fbe090d338acc6a600c338644adfd.jpg", "Url" =>"http://v.qq.com/iframe/player.html?vid=o0169qrkjgl&auto=1");
                        break;
                    case "MUSIC":
                        $content = array();
                        $content = array("Title"=>"最炫民族风", "Description"=>"歌手:凤凰传奇", "MusicUrl"=>"http://mascot-music.stor.sinaapp.com/zxmzf.mp3", "HQMusicUrl"=>"http://mascot-music.stor.sinaapp.com/zxmzf.mp3");
                        break;
                    default:
                        $content = "点击菜单:".$object->EventKey;
                        break;
                }
                break;

效果参考: 微信公众平台开发(97) 图文消息 种的多图文部分。

二、订阅通知

订阅通知的本质还是模板消息,唯一的好处是不关注也能发送成功。但坏处很多,比如,要用户确认一次并弹出一次确认框,每个都要重新来选,对原有业务冲击很大。

所以有点执行不下去。

官方的初衷是减少用模板消息来群发营销的现象,但没考虑正常使用模板消息通知的企业的需求。

目前还是继续用模板消息比较合适。不用理会这个订阅通知。

文档参考: 微信公众平台开发(102) 模板消息

三、稳定版Access Token

原来的Access Token就已经有两种,一种是全局的Access Token,一种是网页授权时候的Access token。

现在又来一个稳定版Access token,它是全局Access Token的替换。

主要用来解决原来多个地方调用全局Access Token导致的更新不同步,接口调用失效问题。

如果有新的地方需要全局类的Access Token,可以就用这个新的,用post方式取

    //构造函数,获取Access Token
    public function __construct($appid = NULL, $appsecret = NULL)
    {
        if($appid && $appsecret){
            $this->appid = $appid;
            $this->appsecret = $appsecret;
        }
        $url = "https://api.weixin.qq.com/cgi-bin/stable_token";
        $data = array('grant_type' => 'client_credential', 'appid' => $this->appid, 'secret' => $this->appsecret);
        $res = $this->http_request($url, json_encode($data));
        $result = json_decode($res, true);
        $this->access_token = $result["access_token"];
        $this->expires_in = $result["expires_in"];

    }

 

其他地方不用改动。

历史文档参考: 微信公众平台开发(26) ACCESS TOKEN

 

四、用户信息

关注事件,用户信息接口调用,都得不到用户信息了。只能获得openid,和语言版本。没有头像、昵称、性别、地区这些重要的信息了。
想要获取用户信息,看下面的网页授权。
 

五、网页授权

多了一个快照页,如果快照页出现,说明网页不规范。腾讯云的页面就经常出现快照页。
获取头像、昵称的唯一方法就是网页授权 ,地区性别这些再网页授权中也没有了
获取方法
require_once('weixin.class.php');
$weixin = new class_weixin();

if (!isset($_GET["code"])){
    $redirect_url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
    $jumpurl = $weixin->oauth2_authorize($redirect_url, "snsapi_userinfo", "123");
    Header("Location: $jumpurl");
}else{
    $access_token_oauth2 = $weixin->oauth2_access_token($_GET["code"]);
    var_dump($access_token_oauth2);
    $userinfo1 = $weixin->oauth2_get_user_info($access_token_oauth2['access_token'], $access_token_oauth2['openid']);
    var_dump($userinfo1);
}

返回

array(5) { 
["access_token"]=> string(110) "90_8nH46skH73VjSNwrXEWDVbm-u848R76ZlfpCADdV8psuzWRR62jOK6ROgJu8TMAJkngc_g0Ye6rZ2Q3hEZehpRx-R8KDa08osRRkB7DlJaM"
["expires_in"]=> int(7200)
["refresh_token"]=> string(110) "90_3s7reykNruYrqoAkJD1cf0RWXghtxId-hb8vc8xXX7BKm_kji6D8HxBjUDZXKmYdQB57tCOpo2xHgpqgLAJsrumBKT0sKJ0Jo96M0g4K8jE"
["openid"]=> string(28) "oJFHu7PiIyd14tDqpqoGemNsqPPM"
["scope"]=> string(15) "snsapi_userinfo"
}
array(9) {
["openid"]=> string(28) "oJFHu7PiIyd14tDqpqoGemNsqPPM"
["nickname"]=> string(7) "方倍"
["sex"]=> int(0)
["language"]=> string(0) ""
["city"]=> string(0) ""
["province"]=> string(0) ""
["country"]=> string(0) ""
["headimgurl"]=> string(131) "https://thirdwx.qlogo.cn/mmopen/vi_32/QAbedw3lQYWplDPTeyJO8ia51lzp7nn4kcBVlEZ12Ts4zZY7MzWX2iccbnvcJpdM3DSIEH0VSn32RZh9fcXia07EQ/132"
["privilege"]=> array(0) { }
}

网页判断是否关注的用法

require_once('weixin.class.php');
$weixin = new class_weixin();

if (!isset($_GET["code"])){
    $redirect_url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
    $jumpurl = $weixin->oauth2_authorize($redirect_url, "snsapi_base", "123");
    Header("Location: $jumpurl");
}else{
    $access_token_oauth2 = $weixin->oauth2_access_token($_GET["code"]);
    $userinfo = $weixin->get_user_info($access_token_oauth2['openid']);
    if ($userinfo["subscribe"] == 0){
        Header("Location: https://mp.weixin.qq.com/s/OHnyngufeyVL3gh-6zyCUw");
    }else{
        var_dump("已关注");
        var_dump($userinfo);
    }
}

 

 代码放到公众号了,关注后回复 2025

 
posted @ 2025-03-09 23:17  方倍工作室  阅读(29)  评论(0)    收藏  举报