Node.JS中如何快速扫描端口并发现局域网内的Web服务器地址(80)


发布者 ourjs  发布时间 1505207561228
关键字 JS学习  Node.JS 
在 Node.JS 中进行端口扫描还是比较方便的,一般会有广播和轮询两种方式。即使用广播和扫描,使用广播发出的消息有时会被路由器屏蔽,所以并不可靠。

使用node.js中的net模块,可以直接尝试向目录主机的某个端口进行连接,如果能建立连接,则说明该地址存在服务器。

var socket = new Socket()
socket.connect(port, host)
socket.on('connect', function() {
  //找到port 和 host 地址
})

所以只要进行255次扫描,则可找到同一网段内所有的Web服务器了。完整的示例代码如下,使用Node.JS扫描的速度极快,几秒内即可完成扫描。

var net     = require('net')
var Socket  = net.Socket

//待扫描的开始网段,可换成192.168.0
var ip      = '10.0.0'
var port    = 80

var scan = function(host, cb) {
  var socket = new Socket()
  var status = null

  socket.setTimeout(1500)

  socket.on('connect', function() {
    socket.end()
    cb && cb(null, host)
  })

  socket.on('timeout', function() {
    socket.destroy()
    cb && cb(new Error('timeout'), host)
  })

  socket.on('error', function(err) {
    cb && cb(err, host)
  })

  socket.on('close', function(err) {

  })

  socket.connect(port, host)
}

for(var i = 1; i <= 255; i++ ) {
  scan(ip+'.'+i, function(err, host) {
    if (err) {
      console.log('Not found', host)
      return
    }

    console.log("Found: ", host)
  })
}

输出结果:

Found:  10.0.0.1
Found:  10.0.0.3
Not found 10.0.0.255
......