微信公众号关注用户的信息拉取

微信关注用户的详细信息均保存在腾讯的微信服务器内。因此,若想获得公众号的关注用户的详细信息,必须通过相应的接口进行调用。而接口规定一次拉取只能拉取一万条openid,当用户较多时我们需要循环调用接口进行拉取操作。

首先我们需要获得accesstoken,这是微信接口调用凭证。

        // 获取微信access_token
        String accessToken = WxBase.getToken();

        // 跨域请求需在服务器端设置响应头
        response.setHeader("Access-Control-Allow-origin", "*");

        JSONArray user_info_list = new JSONArray();// 拉取完全部用户之后存储,也是本方法的最终返回对象。
        JSONArray current_info_list = new JSONArray();// 每次获取之后存储的单元
        JSONArray openidList = new JSONArray();// 作为批量获取用户信息方法batchGetUserInfo的参数

        String nextOpenId = "";
        int counter = 0;
        int total = 0;
        int count = 0;

        do {// 利用do-while循环可以解决粉丝数超过一万或者不足一万的情况,避免代码冗余。
            // 取openid列表
            JSONObject userJsonObject = WxUser.getUserList(accessToken, nextOpenId);
            // total为全部用户,count为本次拉取的用户条数
            total = userJsonObject.getIntValue("total");// 比如是20000
            count = userJsonObject.getIntValue("count");// 10000
            counter += count;// 10000
            nextOpenId = userJsonObject.getString("next_openid");

            JSONObject dataJsonObject = JSONObject.parseObject(userJsonObject.getString("data"));

            JSONArray openidArray = JSON.parseArray(dataJsonObject.getString("openid"));
            Iterator<Object> iterator = openidArray.iterator();

            while (iterator.hasNext()) {
                String openid = (String) iterator.next();

                JSONObject jo = new JSONObject();
                jo.put("openid", openid);
                jo.put("lang", "zh-CN");// TODO:暂时先默认是简体中文,后续可能会做判断

                openidList.add(jo);
            }
            current_info_list = WxUser.batchGetUserInfo(openidList, accessToken);

            user_info_list.addAll(current_info_list);// 全部放入另一个jsonarray中。

        } while (total != counter);// 当累加器没有达到最大值则继续循环,如果累加器已经达到最大粉丝数,则停止获取用户信息。

        log.info(user_info_list);

要获得详细的用户信息,还需要先行调用获取关注用户的openid列表,因为获得用户详细信息的接口需要我们传入这个列表,因此是两次接口调用,如果还是不太明白,就去微信公众开发手册中查看:微信公众平台

另外还有微信硬件接口开发的连接地址:http://iot.weixin.qq.com/wiki/new/index.html?page=3-4-1

在获取到的关注用户详细信息中,用户的关注时间是一串数字,这时我们就需要进行重新格式化一下,同样需要用到循环语句:

        // 将取出的用户列表中的subscribe_time循环格式化
        Iterator<Object> iterator = user_info_list.iterator();
        JSONArray userList = new JSONArray();
        // 处理subscribeTime时需要用到的变量
        JSONObject userJo = new JSONObject();
        Long time = 0L;
        DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String subscribeTime = "";

        while (iterator.hasNext()) {
            // 取出每个用户并转换为JsonObject便于操作
            userJo = (JSONObject) iterator.next();
            // 取出用户关注时间转化为Long型
            time = Long.parseLong(userJo.getString("subscribe_time"));
            // 格式化
            subscribeTime = df.format(new Date(time * 1000L));
            // 放回用户对象中
            userJo.put("subscribe_time", subscribeTime);
            // 放回current_info_list中。
            userList.add(userJo);
        }

        return userList;

至此,我们通过后台Java语句获得了存储于微信服务器上的关注者基本信息。

接下来是前端的显示工作。

由于如今h5的流行,以及spring boot的使用,可以将项目压缩为一个jar包直接放到服务器上运行,而jsp在打包的过程中会非常麻烦,因此我们只能使用jQuery将数据通过动态创建<tr>标签的方式进行展示:

jQuery(document).ready(function() {
    var url = "http://localhost:8080//wxgz/wxuser/alluser";
    $.post(url,
    function(data, status) {
        var thArr = $(".tr-thead").children();
        for (var i = 0; i < data.length; i++) {
            //这里是动态添加tr的过程。
            if (i > 0) {
                var tr = $("tbody").append("<tr class='gradeC'></tr>");
                for (var j = 0; j < thArr.length; j++) {
                    var field = $(".tr-thead").children("th:eq(" + j + ")").text();
                    tr.append("<td>" + eval("data[i]." + field) + "</td>");
                }
            } else {
                for (var j = 0; j < thArr.length; j++) {
                    //循环取出th值,指定需要从data[i]中需要取哪个属性。
                    var field = $(".tr-thead").children("th:eq(" + j + ")").text();
                    $(".gradeX").children("td:eq(" + j + ")").text(eval("data[i]." + field)); //这条语句会把之前的显示覆盖掉。
                }
            }
        }
    });
});

以上jQuery代码虽然看似不多,但是却让我这个对前端知识不甚了解的人花了好久,而且中间也出现过一次关键问题上的错误,即后台传过来的结果的确是个数组,这个数组中的每个元素包含一个关注者的基本信息,每个基本信息是通过键值对的json形式进行编排的,关注者与关注者之间是数组元素的关系,但是每个关注者中的基本信息并非是数组关系,我们并不能通过循环取出,而只能通过key进行读取。而<th>中我们已经写死了表头,因此这里我并没有按照后台返回值的自然顺序进行排序,而是对<th>标签中的值进行顺序取,再通过这个获得的值在后台返回值中进行关注者信息的取出。

此处应当留意eval(“xxxx”)的使用。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
继“Java开发微信朋友圈PC版系统-架构1.0”之后,debug这段时间日撸夜撸,终于赶在春节放假前给诸位带来了这一系统的架构2.0版本,特此分享给诸位进行学习,以掌握、巩固更多的技术栈以及项目和产品开发经验,同时也为即将到来的金三银四跳槽季做准备! 言归正传,下面仍然以问答的方式介绍下本门课程的相关内容! (1)问题一:这是一门什么样的课程? 很明显,本门课程是建立在架构1.0,即 第1门课程 的基础上发布的,包含了架构1.0的内容,即它仍然是一门项目、产品实战课,基于Spring Boot2.X + 分布式中间件开发的一款类似“新浪微博”、“QQ空间”、“微信朋友圈”PC版的互联网社交软件,包含完整的门户网前端 以及 后台系统管理端,可以说是一套相当完整的系统! (2)问题二:架构2.0融入了哪些新技术以及各自有什么作用? 本课程对应着系统架构2.0,即第2阶段,主要目标:基于架构1.0,优化系统的整体性能,实现一个真正的互联网社交产品;其中,可以学习到的技术干货非常多,包括:系统架构设计、Spring Boot2.X、缓存Redis、多线程并发编程、消息中间件RabbitMQ、全文搜索引擎Elastic Search、前后端消息实时通知WebSocket、分布式任务调度中间件Elastic Job、Http Restful编程、Http通信OKHttp3、分布式全局唯一ID、雪花算法SnowFlake、注册中心ZooKeeper、Shiro+Redis 集群Session共享、敏感词自动过滤、Java8 等等; A.  基于Elastic Search实现首页列表数据的初始化加载、首页全文检索;B.  基于缓存Redis缓存首页朋友圈“是否已点赞、收藏、关注、评论、转发”等统计数据;整合Shiro实现集群部署模式下Session共享;C.  多线程并发编程并发处理系统产生的废弃图片、文件数据;D.  基于Elastic Job切片作业调度分布式多线程清理系统产生的废弃图片;E.  基于RabbitMQ解耦同步调用的服务模块,实现服务模块之间异步通信;F.  基于WebSocket实现系统后端 与 首页前端 当前登录用户实时消息通知;G.  基于OKHttp3、Restful风格的Rest API实现ES文档、分词数据存储与检索;H.  分布式全局唯一ID 雪花算法SnowFlake实现朋友圈图片的唯一命名;I.  ZooKeeper充当Elastic Job创建的系统作业的注册中心;J.  为塑造一个健康的网络环境,对用户发的朋友圈、评论、回复内容进行敏感词过滤;K.  大量优雅的Java8  Lambda编程、Stream编程;  (3)问题三:系统运行起来有效果图看吗?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值