本篇文章就是为大家介绍一下我是如何用node去实现扫码群发功能,源代码地址在最后面

获取登录二维码 -> 扫码登录服务端

         

首先介绍一下主要流程,并附上关键代码

1.获取UUID并请求二维码图片

  调用接口:https://login.wx.qq.com/jslogin

  返回数据:code为200表示成功,并返回uuid

function getUUID(){
         var hreq = https.get('https://login.wx.qq.com/jslogin?appid=wx782c26e4c19acffb&redirect_uri=https%3A%2F%2Fwx.qq.com%2Fcgi-bin%2Fmmwebwx-bin%2Fwebwxnewloginpage&fun=new&lang=zh_CN&_=1508239448402',function(ress){
        ress.setEncoding('utf-8');
        var str = '';
        ress.on('end',function(){

            var regxp = new RegExp(/^""$/)
            var uuid = str.split('"')[1];
            console.log('uuid=='+uuid)
            var img = '<img src="https://login.weixin.qq.com/qrcode/'+uuid + '"/>'
            res.send(img)
            getTicket(uuid)

        });
        ress.on('data',function(chunk){
            str+=chunk;
        });
         });
    }

2,通过uuid轮训获取ticket

  调用接口:https://login.wx.qq.com/cgi-bin/mmwebwx-bin/login

  如果返回code是200,表示用户扫码,返回的信息redirect_uri中有登录微信用的ticket等信息

function getTicket(uuid){
        var hreq = https.get('https://login.wx.qq.com/cgi-bin/mmwebwx-bin/login?loginicon=true&uuid='+uuid+'&tip=0&r=-880061546&_='+Date.now(),function(ress){
        ress.setEncoding('utf-8');
        var str = '';
        ress.on('end',function(){
            console.log('请求ticket。。。。。。');
            console.log(str);
            var code = str.split(';')[0].split('=')[1];
            console.log('code='+code);
            if(code == 200){
                if(str.match(/wx2.qq.com/) != null) {
                    wx2 = "2";
                    headers.Host = "wx2.qq.com";
                    headers.Referer = "https://wx2.qq.com/"
                }
                var ticket = str.split('ticket=')[1].split('&uuid')[0];
                console.log('ticket=' + ticket);
                getPassTicket(ticket,uuid);
            }else if(code == 408 || code==201){
                getTicket(uuid);
            }else{
                console.log(str);
                console.log('超时');
            }

        });
        ress.on('data',function(chunk){
            str+=chunk;
        });
         });
    }

3. 获取微信登录唯一标志信息wxsid、skey、pass_ticket

  调用接口:https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxnewloginpage

  返回信息wxsid、skey、pass_ticket,并且会把cookie种植上

  到这一步获取到的信息,在后面所有的请求将畅行无阻

function getPassTicket(ticket,uuid){
        request.get({
          url:'https://wx'+wx2+'.qq.com/cgi-bin/mmwebwx-bin/webwxnewloginpage?ticket='+ticket+'&uuid='+uuid+'&lang=zh_CN&scan='+parseInt(Date.now())+'&fun=new&version=v2&lang=zh_CN',
        }, function(error, response, body){
            console.log('请求PassTicket------->>>>>>>>');
            console.log(body);
            var str = body.toString();
        pass_ticket = str.split('<pass_ticket>')[1].split('</pass_ticket>')[0];
        skey = str.split('<skey>')[1].split('</skey>')[0];
        sid = str.split('<wxsid>')[1].split('</wxsid>')[0];
        uin = str.split('<wxuin>')[1].split('</wxuin>')[0];
        setCookie(response.headers['set-cookie'])
        wxInit()
        });
    }

4.获取联系人列表,并群发消息

  联系人列表调用接口:https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxgetcontact

  返回所有用户联系人信息,每个用户都有此次登录中唯一的ID

 

  发送消息调用接口:https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxsendmsg

  如果BaseResponse.ErrorMsg为空,表示消息发送成功

function getAllUsers(){
        request.get({
            headers: headers,
          url:'https://wx'+wx2+'.qq.com/cgi-bin/mmwebwx-bin/webwxgetcontact?lang=zh_CN&pass_ticket='+pass_ticket+'&r='+Date.now()+'&seq=0&skey='+skey
        }, function(error, response, body){
            console.log('getAllUsers..........')
            console.log(body)
          var list = JSON.parse(body).MemberList;
          console.log(list.length)
          for (var i = 0; i < list.length; i++) {
              var member = list[i];
                console.log(member.NickName,member.UserName);
                // 群发消息要慎重
              // if(member.NickName == '北风吹雪') {
                   // postMsg(myUserName,member.UserName,'消息内容');
                   // break;
              //  }
          }
        });
    }

源代码GitHub地址https://github.com/ColdDay/wxPro(如果对你有帮助请给个star✨,星星到位了后面才会有更有趣的功能,)

node实现微信扫码群发消息《附上github代码》的更多相关文章

  1. C#开发微信门户及应用(45)--微信扫码登录

    在前面随笔<C#开发微信门户及应用(41)--基于微信开放平台的扫码登录处理>介绍了基于微信开放平台接口实现的微信扫码直接登录的过程.本篇介绍对扫码登录的一些改进和处理,以便更方便应用在实 ...

  2. 微信开放平台开发——网页微信扫码登录(OAuth2.0)

    1.OAuth2.0 OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列表),而无需将用户名和密码提供给第三方应用. 允许用户提供 ...

  3. 第三方登录:微信扫码登录(OAuth2.0)

    1.OAuth2.0 OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列表),而无需将用户名和密码提供给第三方应用. 允许用户提供 ...

  4. PC 端微信扫码注册和登录

    一.前言 先声明一下,本文所注重点为实现思路,代码及数据库设计主要为了展现思路,如果对代码效率有着苛刻要求的项目切勿照搬. 相信做过微信开发的人授权这块都没少做过,但是一般来说我们更多的是为移动端的网 ...

  5. Net MVC微信扫码支付

    微信扫码支付+Asp.Net MVC 这里的扫码支付指的是PC网站上面使用微信支付,也就是官方的模式二,网站是Asp.net MVC,整理如下. 一.准备工作 使用的微信API中的统一下单方法,关键的 ...

  6. asp.net core 微信扫码支付(扫码支付,H5支付,公众号支付,app支付)之1

    2018-08-13更新生成二维码的方法 在做微信支付前,首先要了解你需要什么方式的微信支付,目前本人做过的支付包含扫码支付.H5支付.公众号支付.App支付等,本人使用的是asp.net mvc c ...

  7. 微信扫码支付springboot版本

    发布时间:2018-11-06   技术:springboot+freemarker   概述 该项目是一个采用springboot构建的web项目,主要实现了微信扫码支付功能.包含最基本的创建订单, ...

  8. ThinkPHP微信扫码支付接口

    最近折腾微信扫码支付,看了微信官方文档,找了很多网页,发现和文档/demo不匹配,现在自己算是弄出来了(文件名称有所更改),贴出来分享一下 一.将有用的官方lib文件和使用的相关文件放置到vendor ...

  9. Web应用多账号系统设计及微信扫码登录实现

    Web应用多账号系统设计及微信扫码登录实现 1   前言概述 公司对功能测试,性能测试,安全测试等等都做了比较好的自动化后,急需要一个MIS系统来统一管理这些结果及报表. 此MIS系统特点如下: 仅内 ...

随机推荐

  1. 经验总结22--抓取HTML数据,HtmlAgilityPack(续)

    假设获取的数据是HTML的话.我们就须要第三方工具有辅助获取我们须要的数据. 我选用了HtmlAgilityPack这么个工具. 首先肯定去网上下载一个,然后引用到项目中.下载地址:http://ht ...

  2. 【SqlServer】【问题收集】删除同一张表中完全相同的记录

    1   概述 在Sqlserver中,当通过SqlServer设计器删除同一张表中两条完全相同的记录时,会弹出如下提示: 点击“是” 弹出如下提示,不让删除 2   问题解决 这个问题很简单,用DEL ...

  3. ASP.NET Core 异常重试组件 Polly

    Polly 是一种 .NET 弹性和瞬态故障处理库,允许开发人员以流畅和线程安全的方式表达策略,如重试,断路器,超时,隔离隔离和备用,Polly 适用于 .NET 4.0,.NET 4.5 和 .NE ...

  4. idea历史版本下载

    https://confluence.jetbrains.com/display/IntelliJIDEA/Previous+IntelliJ+IDEA+Releases

  5. 关于IntelliJ IDEA有时候快捷键无效的说明

    1.这个原因最大的因素可能就是 搜狗输入法了, 关闭搜狗输入法,ok, 2.也可能是qq快捷键冲突,关闭它. 3.也可能是搜狗输入法快捷键冲突,关闭它.

  6. TypeScript学习笔记之类

    TypeScript的类,简单地定义如下: class Person { x: number; // 默认为public类型 y: number; constructor(x1: number, y1 ...

  7. Lua中使用状态机FSM简单例子

    FSM 有限状态机: 一个有限状态机是一个设备,或者是一个设备模型,具有有限数量的状态,它可以在任何给定的时间根据输入进行操作,使得一个状态变换到另一个状态,或者是使一个输入或者一种行为的发生.一个有 ...

  8. ArcGIS API for JavaScript 中的数据类型【vs】GPServer的数据类型

    熟悉GPServer的同学肯定知道,GPServer在10.1的ArcMap后需要执行成功一次才能发布. 发布GPServer,可以是ArcMap的工具箱的工具,也可以是自己写的模型. 不管是ArcM ...

  9. 视觉SLAM

    SLAM:Simultaneous Localization And Mapping.中文:同时定位与地图重建. 它是指搭载特定传感器的主体,在没有实验先验信息的情况下,于运动过程中建立环境的模型,同 ...

  10. bzoj 1996: [Hnoi2010]chorus 合唱队

    Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Output 8 HINT Source 因为只会在区间的两端进行 ...