震惊! 再也不怕蹭网被发现了!

时间:2022-07-23
本文章向大家介绍震惊! 再也不怕蹭网被发现了!,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

今天下了个wifi共享精灵, 连上了别人的网, 从此告别无网生活 于是顺手访问了下 192.168.0.1 居然不用输管理员密码就进入后台了...

image.png

于是和朋友聊天, 想搞个实时监控, 看看如果对方连上网, 我就低调点, 当然都是搞的玩的

需要相关技术

  • 腾达路由器...
  • NodeJS
  • axios --- 用于请求路由器接口
  • wunderbar --- 命令行绘制图表(装x
  • snoretoast --- 系统通知程序( 我看vue-cli用的就是这个,不然还不知道

总体原理

  • 通过请求api获取路由器数据
  • 通过判断联网设备,来判断是否有出了自己之外的人连上, 通过判断前后的长度差,来判断是否有新设备加入

代码

const axios = require('axios') // http请求库
const wunderbar = require('@gribnoysup/wunderbar') // 命令行图表库
const WindowsToaster = require('node-notifier').WindowsToaster // 弹框通知库
let notifier = new WindowsToaster({ // 配置SnoreToast
  withFallback: false,
  customPath: './SnoreToast.exe'
});

let my = '' // 自己设备的ip
let num = 0 // 当前联入设备总数
let allDown = '' // 总下载
let allUp = '' // 总上传
let downSpeed = [] // 下载速度数组
let deviceList = [] // 除去自己的设备


function getData() {
  // 请求设备网络使用数据
  axios.get('http://192.168.0.1/goform/getQos?random=0.2296175026847045')
    .then(res => {
      let result = res.data
      my = result.localhost
      downSpeed = []
      upSpeed = []
      deviceList = []
      result.qosList.map(v => {
        if (v.qosListHostname !== 'DESKTOP-QKBMCV7' && v.qosListHostname !== 'Unknown') {
          deviceList.push(v.qosListHostname)
        }
        // 将数据遍历到数组中, 图表需要的数据格式 {value: 你的数据, label: 数据的标题, color: 数据的颜色} 后两项不是必须的
        downSpeed.push({
          value: v.qosListDownSpeed,
          label: v.qosListHostname
        })
      })
    })
    .catch(err => {
      console.log(error)
    })
  // 请求设备联网总数据
  axios.get('http://192.168.0.1/goform/getStatus?0.3297709679659049')
    .then(res => {
      let result = res.data
      allDown = result.statusDownSpeed
      allUp = res.data.statusUpSpeed
      num = res.data.statusOnlineNumber
    })
    .catch(err => {
      console.log(err)
    })
}

// 绘图方法
const printData = () => {
  const { chart, legend, scale, __raw } = wunderbar(downSpeed, {
    min: 0,
    length: 42,
    format: (n) => `${n}KB/s`
  });

  // 清空命令行
  process.stdout.write('n');
  process.stdout.write('33[0f');
  process.stdout.write('33[2J');

  // 绘制图表
  console.log()
  console.log('==========================================');
  console.log(`当前时间:${new Date().toLocaleTimeString()}`)
  console.log(`本机当前IP: ${my}t 当前联网设备:${num}t 总下载速度:${allDown}KB/st 总上传速度:${allUp}KB/st`);
  console.log('==========================================');
  console.log(chart);
  console.log();
  console.log(legend);
  console.log();
};

// 定时刷新
let otherDeviceLength = 0 // 设备计数
setInterval(async () => {
  await getData()
  // 判断是否有新设备加入
  if (deviceList.length > otherDeviceLength) {
    otherDeviceLength = deviceList.length
    // 桌面通知
    notifier.notify({
      title: '有人连进来了',
      message: '低调点!低调点!低调点!',
      icon: './xu.jpg'
    },
      function (error, response) {
        console.log(response)
      });
  } else {
    otherDeviceLength = deviceList.length
  }
  await printData()
}, 5000)

效果

image.png

讲真的,我喜欢这种质感的命令行

代码地址

https://github.com/klren0312/RubbingNetNotice

参考资料