zoukankan      html  css  js  c++  java
  • 微信公众平台开发(87) 获取关注者列表

    本文介绍在微信公众平台上如何使用高级接口开发获取关注者列表的功能。

    一、接口介绍

    公众号可通过本接口来获取帐号的关注者列表,关注者列表由一串OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的)组成。一次拉取调用最多拉取10000个关注者的OpenID,可以通过多次拉取的方式来满足需求。

    接口调用请求说明

    http请求方式: GET(请使用https协议)
    https://api.weixin.qq.com/cgi-bin/user/get?access_token=ACCESS_TOKEN&next_openid=NEXT_OPENID
    
    参数是否必须说明
    access_token 调用接口凭证
    next_openid 第一个拉取的OPENID,不填默认从头开始拉取

    返回说明

    正确时返回JSON数据包:

    {"total":2,"count":2,"data":{"openid":["","OPENID1","OPENID2"]},"next_openid":"NEXT_OPENID"}
    参数说明
    total 关注该公众账号的总用户数
    count 拉取的OPENID个数,最大值为10000
    data 列表数据,OPENID的列表
    next_openid 拉取列表的后一个用户的OPENID

    错误时返回JSON数据包(示例为无效AppID错误):

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

    附:关注者数量超过10000时

    当公众号关注者数量超过10000时,可通过填写next_openid的值,从而多次拉取列表的方式来满足需求。

    具体而言,就是在调用接口时,将上一次调用得到的返回中的next_openid值,作为下一次调用中的next_openid值。

    示例如下:

    公众账号A拥有23000个关注的人,想通过拉取关注接口获取所有关注的人,那么分别请求url如下:
    https://api.weixin.qq.com/cgi-bin/user/get?access_token=ACCESS_TOKEN 
    返回结果:
    {
      "total":23000,
      "count":10000,
      "data":{"
         openid":[
            "OPENID1",
            "OPENID2",
            ...,
            "OPENID10000"
         ]
       },
       "next_openid":"NEXT_OPENID1"
    }
    https://api.weixin.qq.com/cgi-bin/user/get?access_token=ACCESS_TOKEN&next_openid=NEXT_OPENID1
    返回结果:
    {
       "total":23000,
       "count":10000,
       "data":{
         "openid":[
           "OPENID10001",
           "OPENID10002",
           ...,
           "OPENID20000"
         ]
       },
       "next_openid":"NEXT_OPENID2"
    }
    https://api.weixin.qq.com/cgi-bin/user/get?access_token=ACCESS_TOKEN&next_openid=NEXT_OPENID2
    返回结果(关注者列表已返回完时,返回next_openid为空):
    {
       "total":23000,
       "count":3000,
       "data":{"
           "openid":[
             "OPENID20001",
             "OPENID20002",
             ...,
             "OPENID23000"
           ]
       },
       "next_openid":" "
    }
    
    

    二、程序实现

    $access_token = "";
    
    $url = "https://api.weixin.qq.com/cgi-bin/user/get?access_token=$access_token";
    $result = https_request($url);
    $jsoninfo = json_decode($result, true);
    var_dump($result);
    

    招行后,返回类似如下:

    {
        "total": 200,
        "count": 200,
        "data": {
            "openid": [
                "o7Lp5t6n59DeX3U0C7Kric9qEx-Q",
                "o7Lp5t5BZDl22PcjIliHp03kzgBE"
            ]
        },
        "next_openid": "o7Lp5t5BZDl22PcjIliHp03kzgBE"
    }

    对于超过1万以后的数,循环执行上述程序即可,将这些openid存入数据库,就获得了关注者的列表。

    该接口的作用主要是配合获取用户基本信息以及用户分组接口,获得所有关注者的基本信息及分组。

    ====================================================================

    方倍工作室微信公众平台账号关注方法:
    1. 微信通讯录-添加朋友-查找公众号-搜索“方倍工作室”
    2. 微信通讯录-添加朋友-搜号码-输入“pondbaystudio”
    3. 使用微信扫描下面的二维码

  • 相关阅读:
    Linux常用命令
    安装最新版的wampserver,可以兼容php5和php7
    PHP程序员的技术成长规划
    ztreeSearch
    xmlUtil 解析 创建
    EXCEL 读取
    线程池 Future 带返回结果
    cxf 创建动态webService
    Map 和 javaBean转换
    线程池 http请求
  • 原文地址:https://www.cnblogs.com/lanzhi/p/6467501.html
Copyright © 2011-2022 走看看