局域网通常是分布在一个有限地理范围内的网络系统,一般所涉及的地理范围只有几公里。局域网专用性非常强,具有比较稳定和规范的拓扑结构。在 Node.JS 中进行端口扫描还是比较方便的,一般会有广播和轮询两种方式。下文重点给大家介绍node.js 扫描端口并发现局域网内的web服务器地址的方法,,一起看看吧
方法步骤
在 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)
})
}