zoukankan      html  css  js  c++  java
  • Java微信公众平台开发之用户管理(用户基本信息和关注列表)

    一、用户基本信息

    在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的。对于不同公众号,同一用户的openid不同)。公众号可通过本接口来根据OpenID获取用户基本信息,包括昵称、头像、性别、所在城市、语言和关注时间。

    1.根据文档说明,封装用户的基本信息

    /**
     * 微信用户基本信息
     * @author fjing
     *
     */
    public class WeiXinUserInfo {
    	private int subscribe;// 用户是否订阅该公众号标识,值为0时,代表此用户没有关注该公众号,拉取不到其余信息。
    	private String openid; // 用户的标识,对当前公众号唯一
    	private String nickname;// 用户的昵称
    	private int sex;// 用户的性别,值为1时是男性,值为2时是女性,值为0时是未知
    	private String city;// 用户所在城市
    	private String country;// 用户所在国家
    	private String province;// 用户所在省份
    	private String language;// 用户的语言,简体中文为zh_CN
    	private String headimgurl;// 用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空。若用户更换头像,原有头像URL将失效。
    	private String subscribe_time;// 用户关注时间,为时间戳。如果用户曾多次关注,则取最后关注时间
    	private String unionid;// 只有在用户将公众号绑定到微信开放平台帐号后,才会出现该字段。
    	private String remark;// 公众号运营者对粉丝的备注,公众号运营者可在微信公众平台用户管理界面对粉丝添加备注
    	private int groupid;// 用户所在的分组ID(兼容旧的用户分组接口)
    	private String tagid_list; // 用户被打上的标签ID列表
    	
    	get/set方法
    }

    2.通过openid获取用户的基本信息

    private final static String WECHAT_USER_INFO_URL = "ttps://api.weixin.qq.com/cgi-bin/user/info"; //?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN 
    
    /**
     * 获取微信用户基本信息
     * @param accessToken 
     * @param openid 
     * @return
     */
    public WeiXinUserInfo getUserInfo(String accessToken, String openid){
    	WeiXinUserInfo weixinUserInfo = null;
    	Map<String,String> map = new TreeMap<String,String>();
    	map.put("access_token", accessToken);
    	map.put("openid", openid);
    	String result = HttpRequestUtil.HttpsDefaultExecute(HttpRequestUtil.GET_METHOD, WECHAT_USER_INFO_URL, map, "");
    	try {
    		weixinUserInfo = new Gson().fromJson(result, WeiXinUserInfo.class);
    	} catch (JsonSyntaxException e) {
    		weixinUserInfo = null;
    	}
    	return weixinUserInfo;
    	
    }

    3.官方的批量获取我直接无视了


    二、获取关注列表

    公众号可通过本接口来获取帐号的关注者列表,关注者列表由一串OpenID组成。一次拉取调用最多拉取10000个关注者的OpenID,可以通过多次拉取的方式来满足需求。

    官方实例

    当公众号关注者数量超过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":"OPENID10000"
    }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":"OPENID20000"
    }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":"OPENID23000"
    }

    1.根据返回的json封装实体类

    单个openid的WeiXinUserData.java

    public class WeiXinUserData {
    
    	private List<String> openid;
    
    	public List<String> getOpenid() {
    		return openid;
    	}
    
    	public void setOpenid(List<String> openid) {
    		this.openid = openid;
    	}
    }

    WeiXinUserList.java

    /**
     * 关注用户列表
     * @author fjing
     *
     */
    public class WeiXinUserList {
    	// 总关注用户数
    	private int total;
    	// 获取的OpenId个数
    	private int count;
    	// OpenId列表
    	private WeiXinUserData data;
    	// 最后一个用户的openid
    	private String next_openid;
    	
    	get/set方法
    }

    2.根据接口获取所有的关注者的openid

    private final static String WECHAT_USER_GET_URL = "https://api.weixin.qq.com/cgi-bin/user/get"; //?access_token=ACCESS_TOKEN&next_openid=NEXT_OPENID
    
    public List<String> findWeiXinUserList(List<String> openidList, String accessToken, String nextOpenid){	
    	WeiXinUserList weixinUserList = null;
    	Map<String,String> map = new TreeMap<String,String>();
    	map.put("access_token", accessToken);
    	if(StringUtils.isNotBlank(nextOpenid)){
    		map.put("next_openid", nextOpenid);
    	}
    	String result = HttpRequestUtil.HttpsDefaultExecute(HttpRequestUtil.GET_METHOD, WECHAT_USER_GET_URL, map, "");
    	if(result != null){
    		try {
    			weixinUserList = new Gson().fromJson(result, WeiXinUserList.class);
    			openidList = new ArrayList<String>();
    			if(weixinUserList.getCount() <= 10000 && weixinUserList.getCount() >0){
    				openidList.addAll(weixinUserList.getData().getOpenid());
    			}else{
    				//如果大于10000的,继续查询
    				findWeiXinUserList(openidList, accessToken, weixinUserList.getNext_openid());
    			}	
    		} catch (JsonSyntaxException e) {
    			openidList = null;
    		}
    	}
    	return openidList;
    }

    三、批量获取用户的基本信息

    提供一个思想,准备好所有用户的openid -->遍历查询-->如果token过期(错误码识别出)-->重新获取token(从数据库或者文件)-->再继续查询                                                           


    本文为Phil Jing原创文章,未经博主允许不得转载,如有问题请直接回复或者加群。
  • 相关阅读:
    C#中关于@的用法
    c++ 中__declspec 的用法
    #pragma详细解释(一)
    memmove 和 memcpy的区别
    【niubi-job——一个分布式的任务调度框架】----安装教程
    [异能程序员]第一章 酒后事发(第一更)
    博客园的最后一篇博文,还是要离开了(附带个人博客源码分享)
    五一假期——技术之路上的坎儿
    deerlet-redis-client添加集群支持,邀请各路大神和菜鸟加入。
    从日常开发说起,浅谈HTTP协议是做什么的。
  • 原文地址:https://www.cnblogs.com/phil_jing/p/15615884.html
Copyright © 2011-2022 走看看