一、用户基本信息
在关注者与公众号产生消息交互后,公众号可获得关注者的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(从数据库或者文件)-->再继续查询