用node撸一个监测复联4开售短信提醒的实现代码


Posted in Javascript onApril 10, 2019

背景

北美复仇者联盟4首映电影票eBay上面已经2500美元一张票了,为了避免抢不到票 写了个监控复仇者联盟4开售就发送短信的脚本,这样我们可以第一时间进行抢票,毕竟抢到就是赚到 。。。

思路

node编写一个抓包脚本监测在售的电影中是否有 “复仇者联盟” 这几个关键词,如果有则直接发送短信~

实现

要想实现我的想法,运用到了2个node库:superagent 和 cheerio ,分别实现发送请求和dom节点分析。

设置定时器

这里用 setInterval 来实现定时,每隔60s 抓取一次网页数据

function intervalFunc() {
  superagent.get('https://maoyan.com/films?sortId=2').end((err, res) => {
    if (err) {
      console.log(` - ${err}`)
    } else {
      getFilms(res)
    }
  });
}

var timer = setInterval(intervalFunc, 10000);

分析dom节点

用node撸一个监测复联4开售短信提醒的实现代码

我们只需要获取到 div 的class 是 channel-detail 就可以了 ~

let getFilms = (res) => {
  let $ = cheerio.load(res.text);
  var isOn = false
  $('.channel-detail').each((idx, ele) => {
    if ($(ele).text().indexOf("复仇") != -1) {
      isOn = true
    }
  });
  if (isOn) {
    for (const phone of phoneArray) {
      sendMessage(phone)
    }
    clearInterval(timer)
  } else {
    console.log("影片未上映....")
  }
};

这里如果监测到影片已经上映了记得关闭定时器 ~

发送短信

function sendMessage(mobile) {
  var http = require('http');
  var username = "";
  var secretkey = "";
  
  var path = "/sms_token?ddtkey=" + username + "&secretkey=" + secretkey
    + "&mobile=" + mobile + "&content=Go"

  var options = {
    host: '112.124.17.46',
    port: 7001,
    path: path,
    method: 'GET',
    headers: {
      'Content-Type': 'application/json'
    }
  };
  http.get(options, function (res) {
    var resData = "";
    res.on("data", function (data) {
      resData += data;
    });
    res.on("end", function () {
      console.log("影片已经上映,短信通知成功")
    });
  })
}

总结

1、node 抓包采用 superagent 和 cheerio
2、定时器关闭采用 clearInterval

完整的代码地址:https://github.com/ChengRuipeng/maoyan

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Prototype1.5 rc2版指南最后一篇之Position
Jan 10 Javascript
JavaScript 提升运行速度之循环篇 译文
Aug 15 Javascript
用JQuery实现表格隔行变色和突出显示当前行的代码
Feb 10 Javascript
jquery ajaxSubmit 异步提交的简单实现
Feb 28 Javascript
Jquery $.getJSON 在IE下的缓存问题解决方法
Oct 10 Javascript
实例讲解避免javascript冲突的方法
Jan 03 Javascript
VUE中使用Vue-resource完成交互
Jul 21 Javascript
vuex中使用对象展开运算符的示例
Sep 25 Javascript
实用的Vue开发技巧
May 30 Javascript
bootstrap table列和表头对不齐的解决方法
Jul 19 Javascript
openlayers 3实现车辆轨迹回放
Sep 24 Javascript
vue vant中picker组件的使用
Nov 03 Javascript
从0到1搭建Element的后台框架的方法步骤
Apr 10 #Javascript
详解vue.js移动端配置flexible.js及注意事项
Apr 10 #Javascript
小程序分享模块超级详解(推荐)
Apr 10 #Javascript
关于JavaScript 数组你应该知道的事情(推荐)
Apr 10 #Javascript
Vue中computed、methods与watch的区别总结
Apr 10 #Javascript
JavaScript 性能提升之路(推荐)
Apr 10 #Javascript
详解vue-cli3 中跨域解决方案
Apr 10 #Javascript
You might like
PHP项目开发中最常用的自定义函数整理
2010/12/02 PHP
PHP PDO fetch 模式各种参数的输出结果一览
2015/01/07 PHP
Symfony生成二维码的方法
2016/02/04 PHP
php强大的时间转换函数strtotime
2016/02/18 PHP
PHP+Ajax验证码验证用户登录
2016/07/20 PHP
PHP7中I/O模型内核剖析详解
2019/04/14 PHP
jQuery is()函数用法3例
2014/05/06 Javascript
JavaScript中string对象
2015/06/12 Javascript
Javascript使用post方法提交数据实例
2015/08/03 Javascript
jQuery+css实现的时钟效果(兼容各浏览器)
2016/01/27 Javascript
Node.js connect ECONNREFUSED错误解决办法
2016/09/15 Javascript
JS比较两个数值的大小实例
2016/11/25 Javascript
js实现图片懒加载效果
2017/07/17 Javascript
利用pm2部署多个node.js项目的配置教程
2017/10/22 Javascript
BootStrap自定义popover,点击区域隐藏功能的实现
2018/01/23 Javascript
JS常用的几种数组遍历方式以及性能分析对比实例详解
2018/04/11 Javascript
Vue 实现分页与输入框关键字筛选功能
2020/01/02 Javascript
微信小程序分享小程序码的生成(带参数)以及参数的获取
2020/03/25 Javascript
python实现ip查询示例
2014/03/26 Python
Tornado服务器中绑定域名、虚拟主机的方法
2014/08/22 Python
Python PO设计模式的具体使用
2019/08/16 Python
HTML5和以前HTML4的区别整理
2013/10/20 HTML / CSS
英国户外服装品牌:Craghoppers
2019/04/25 全球购物
size?法国官网:英国伦敦的球鞋精品店
2020/03/15 全球购物
美国沙龙美发产品购物网站:Hair.com by L’Oreal
2020/11/09 全球购物
瑞士男士时尚网上商店:Babista
2020/05/14 全球购物
C#怎么让一个窗口居中显示?
2015/10/20 面试题
制作部班长职位说明书
2014/02/26 职场文书
《第一次抱母亲》教学反思
2014/04/16 职场文书
创业培训计划书
2014/05/03 职场文书
商务专员岗位职责范本
2014/06/29 职场文书
保险内勤岗位职责
2015/04/13 职场文书
中学团支部工作总结
2015/08/13 职场文书
高考满分作文赏析(2篇)
2019/08/12 职场文书
jquery插件实现图片悬浮
2021/04/16 jQuery
Python接口自动化之文件上传/下载接口详解
2022/04/05 Python