一個簡單的 ping 工具。支援TCP/UDP/ICMP協定。
平格斯可以...
發送 ICMP 回顯請求和 ttl 追蹤路由。
發送 ping、掃描 TCP/UDP 連接埠以及抓取橫幅。
使用 UDP ping 發送魔術包(LAN 喚醒)。
pingus.Ping
'ready'
'result'
'error'
ping.send()
pingus.PingTCP
擴充: pingus.Ping
new PingTCP(options)
pingtcp.send()
pingtcp.scan()
pingus.PingUDP
擴充: pingus.Ping
new PingUDP(options)
pingudp.send()
pingudp.scan()
pingus.PingICMP
擴充: pingus.Ping
new PingICMP(options)
pingicmp.send()
pingicmp.traceroute()
Callback
或Promise
( async/await
)pingus.tcp(options[, callback])
pingus.tcpscan(options[, callback])
pingus.udp(options[, callback])
pingus.udpscan(options[, callback])
pingus.wol(mac, options[, callback])
pingus.icmp(options[, callback])
pingus.traceroute(options[, callback])
npm i pingus
如果安裝過程中發生錯誤,可能是由於以下軟體包安裝失敗所造成的。
可以透過安裝GCC編譯器來修復。
在Ubuntu中:
sudo apt-get install -y build-essential
在 Windows 中:
安裝Visual Studio
包括Desktop development with C++
。
// TCP Ping to localhost:22
import pingus from 'pingus' ; // ESM, Typescript
const pingus = require ( 'pingus' ) ; // CJS
pingus . tcp ( { host : 'localhost' , port : 22 } ) . then ( console . log ) ;
// Result
{
type : 'ping/tcp' ,
status : 'open' ,
host : 'localhost' ,
ip : IP { label : '127.0.0.1' } ,
ips : [ IP { label : '127.0.0.1' } ] ,
time : 2 ,
port : 22 ,
name : 'ssh' ,
banner : 'SSH-2.0-OpenSSH_8.9p1 Ubuntu-3'
toPrimitiveJSON : [ Function ( anonymous ) ]
}
pingus.Ping
pingus.Ping
是具有以下事件的EventEmitter
:
'ready'
result
<Object>
當準備好(解析 DNS、過濾 Bogon IP)在呼叫ping.send()
後發送 ping 時發出。
import pingus from 'pingus' ;
const ping = new pingus . PingTCP ( {
host : 'example.com' ,
} ) ;
ping . on ( 'ready' , ( result ) => {
const data = result . toPrimitiveJSON ( ) ;
console . log ( 'pingttarget:t' , data . host ) ;
console . log ( 'tips:t' , data . ips ) ;
} ) ;
ping . send ( ) ;
ping target: example.com
ips: [ '93.184.215.14', '2606:2800:021f:cb07:6820:80da:af6b:8b2c' ]
'result'
result
<Object>
ping 資料的結果。
import pingus from 'pingus' ;
const ping = new pingus . PingTCP ( {
host : 'example.com' ,
} ) ;
ping . on ( 'result' , ( result ) => {
const data = result . toPrimitiveJSON ( ) ;
console . log ( result ) ;
} ) ;
ping . send ( ) ;
{
type : 'ping/tcp' ,
status : 'open' ,
host : 'example.com' ,
ip : '93.184.215.14' ,
ips : [ '93.184.215.14' , '2606:2800:021f:cb07:6820:80da:af6b:8b2c' ] ,
time : 134 ,
port : 80 ,
name : 'http' ,
banner : ''
}
'error'
<Error>
result
<Object>
發生錯誤時發出。 result
有錯誤發生前的最後一條語句和錯誤代碼。
ping.send()
發送 ping。請參閱用法中的一些範例
pingus.PingTCP
擴充: pingus.Ping
TCP ping 類別。
pingus.PingTCP
是pingus.Ping
的類型
new PingTCP(options)
options
<Object>
host
<string>
設定目標主機名稱(網域)或 IP 位址。port
<number>
使用pingtcp.send()
設定目標連接埠。預設值: 80
ports
<Array>
| <string>
使用pingtcp.scan()
時設定目標連接埠。使用連接埠號碼或查詢字串的陣列。參見範例。timeout
<number>
設定逾時。預設值: 2000
resolveDNS
<boolean>
當host
為網域位址時解析 DNS A
和AAAA
記錄。預設值: true
dnsServer
<string>
設定 DNS 伺服器來解析 DNS 記錄。filterBogon
<boolean>
過濾host
中的 bogon IP 位址。預設值: true
options.ports
的範例ports: [ 21 , 22 , 80 , 443 ] ; // Scan port 21, 22, 80, 443
ports: '21,22,80,443' ; // Scan port 21, 22, 80, 443
ports: '21-80' ; // Scan ports in range 21 to 80 (21, 22, 23 ... 78, 79, 80)
ports: '21-25,80,443' ; // Scan ports in range 21 to 25 and 80, 443
ports: '@' ; // Scan most used 1024 ports in protocol
ports: '*' ; // Scan all ports (1 to 65535)
pingtcp.send()
請參閱ping.send()
。使用中的一些範例。
pingtcp.scan()
使用 TCP ping 掃描連接埠。傳回事件結果: 'result'
。請參閱用法中的一些範例。
pingus.PingUDP
擴充: pingus.Ping
UDP ping 類別。
pingus.PingUDP
是pingus.Ping
的類型
new PingUDP(options)
options
<Object>
host
<string>
設定目標主機名稱(網域)或 IP 位址。port
<number>
使用pingudp.send()
時設定目標連接埠。預設值: 68
ports
<Array>
| <string>
使用pingudp.scan()
時設定目標連接埠。使用連接埠號碼或查詢字串的陣列。與 PingTCP 相同。參見範例。buffer
<Buffer>
設定在已連線的 UDP ping 套接字上傳送時的緩衝區。body
<string>
在已連接的 UDP ping 套接字上傳送時設定正文。設定buffer
選項時將被忽略。bytes
<number>
設定在已連接的 UDP ping 套接字上傳送時的隨機位元組長度。設定body
選項時將被忽略。預設值: 32
timeout
<number>
設定逾時。預設值: 2000
resolveDNS
<boolean>
當host
為網域位址時解析 DNS A
和AAAA
記錄。預設值: true
dnsServer
<string>
設定 DNS 伺服器來解析 DNS 記錄。filterBogon
<boolean>
過濾host
中的 bogon IP 位址。預設值: true
pingudp.send()
請參閱ping.send()
。使用中的一些範例。
pingudp.scan()
與pingtcp.scan()
類似。
使用 UDP ping 掃描連接埠。傳回事件結果: 'result'
。請參閱用法中的一些範例。
pingus.PingICMP
擴充: pingus.Ping
ICMP ping 類別。
pingus.PingICMP
是pingus.Ping
的類型
new PingICMP(options)
options
<Object>
host
<string>
設定目標主機名稱(網域)或 IP 位址。ttl
<number>
設定 ttl。預設值: 128
ttln
<number>
設定使用pingicmp.traceroute()
時的起始 ttl。預設值: 1
ttlx
<number>
使用pingicmp.traceroute()
時設定最大 ttl。預設值: 64
timeout
<number>
設定逾時。預設值: 2000
timeoutx
<number>
使用pingicmp.traceroute()
時設定最大超時堆疊。預設值: 8
resolveDNS
<boolean>
當host
為網域位址時解析 DNS A
和AAAA
記錄。預設值: true
dnsServer
<string>
設定 DNS 伺服器來解析 DNS 記錄。filterBogon
<boolean>
過濾host
中的 bogon IP 位址。預設值: true
pingicmp.send()
請參閱ping.send()
。使用中的一些範例。
pingicmp.traceroute()
運行追蹤路由。使用中的一些範例。
Callback
或Promise
( async/await
)請參閱發送 Ping 樣式中的範例。
pingus.tcp(options[, callback])
發送 TCP ping。
pingus.tcpscan(options[, callback])
使用 TCP ping 掃描連接埠。
pingus.udp(options[, callback])
發送 UDP ping。
pingus.udpscan(options[, callback])
使用 UDP ping 掃描連接埠。
pingus.wol(mac, options[, callback])
mac
<string>
設定目標 MAC 位址。options
<Object>
與new PingUDP(options)
的選項相同發送魔術包 UDP ping 以使用 WOL 功能。
pingus.icmp(options[, callback])
發送 ICMP ping。
pingus.traceroute(options[, callback])
運行追蹤路由。
ESM(打字稿)
import pingus from 'pingus' ;
中山大學
const pingus = require ( 'pingus' ) ;
Class
擴展EventEmitter
// TCP ping to localhost:80
new pingus . PingTCP ( { host : 'localhost' } )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. send ( ) ;
Callback
// TCP ping to localhost:80
pingus . tcp ( { host : 'localhost' } , ( err , result ) => {
if ( err ) {
throw err ;
}
console . log ( result ) ;
} ) ;
Promise
// TCP ping to localhost:80
pingus
. tcp ( { host : 'localhost' } )
. then ( ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. catch ( ( err ) => {
throw err ;
} ) ;
async/await
// TCP ping to localhost:80
const result = await pingus . tcp ( { host : 'localhost' } ) ;
console . log ( result . toPrimitiveJSON ( ) ) ;
{
type : 'ping/tcp' ,
status : 'open' ,
host : 'localhost' ,
ip : '127.0.0.1' ,
ips : [ '127.0.0.1' ] ,
time : 2 ,
port : 80 ,
name : 'http' ,
banner : ''
}
// TCP ping to localhost:22
new pingus . PingTCP ( { host : 'localhost' , port : 22 } )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. send ( ) ;
{
type : 'ping/tcp' ,
status : 'open' ,
host : 'localhost' ,
ip : '127.0.0.1' ,
ips : [ '127.0.0.1' ] ,
time : 2 ,
port : 22 ,
name : 'ssh' ,
banner : 'SSH-2.0-OpenSSH_8.9p1 Ubuntu-3'
}
// TCP ping scan to localhost
new pingus . PingTCP ( {
host : 'localhost' ,
ports : [ 21 , 22 , 80 , 443 , 3306 , 8080 ] ,
} )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. scan ( ) ;
{
type : 'ping/tcp/scan' ,
status : 'finish' ,
host : 'localhost' ,
ip : '127.0.0.1' ,
ips : [ '127.0.0.1' ] ,
time : 2009 ,
port : 80 ,
name : 'http' ,
banner : '' ,
ports : [ 21 , 22 , 80 , 443 , 3306 , 8080 ] ,
statuses : {
open : [ 22 , 80 , 8080 ] ,
reset : [ ] ,
close : [ 21 , 443 , 3306 ] ,
filtered : [ ] ,
error : [ ]
} ,
names : {
'21' : 'ftp' ,
'22' : 'ssh' ,
'80' : 'http' ,
'443' : 'https' ,
'3306' : 'mysql' ,
'8080' : 'http-alt'
} ,
banners : { '22' : 'SSH-2.0-OpenSSH_8.9p1 Ubuntu-3' } ,
errors : { }
}
// UDP ping to localhost:19132
new pingus . PingUDP ( { host : 'localhost' , port : 19132 } )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. send ( ) ;
{
type : 'ping/udp' ,
status : 'close' ,
host : 'localhost' ,
ip : '127.0.0.1' ,
ips : [ '127.0.0.1' ] ,
time : 2 ,
port : 19132 ,
name : 'minecraft-be'
}
// UDP ping scan to localhost
new pingus . PingUDP ( {
host : 'localhost' ,
ports : [ 67 , 68 , 161 , 162 , 445 ] ,
} )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. scan ( ) ;
{
error : undefined ,
type : 'ping/udp/scan' ,
status : 'finish' ,
host : 'localhost' ,
ip : '127.0.0.1' ,
ips : [ '127.0.0.1' ] ,
time : 2003 ,
ports : [ 67 , 68 , 161 , 162 , 445 ] ,
statuses : {
open : [ 68 ] ,
reset : [ ] ,
close : [ 67 , 161 , 162 , 445 ] ,
filtered : [ ] ,
error : [ ]
} ,
names : {
'67' : 'bootps' ,
'68' : 'bootpc' ,
'161' : 'snmp' ,
'162' : 'snmptrap' ,
'445' : 'microsoft-ds'
} ,
banners : { } ,
errors : { }
}
// Send magic packet using UDP ping to 00-00-00-00-00-00
pingus
. wol ( '00-00-00-00-00-00' )
. then ( ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. catch ( ( error ) => {
throw error ;
} ) ;
{
type : 'ping/udp' ,
status : 'open' ,
host : '255.255.255.255' ,
ip : '255.255.255.255' ,
ips : [ '255.255.255.255' ] ,
time : 2 ,
port : 9 ,
name : 'discard'
}
// ICMP ping to example.com
new pingus . PingICMP ( { host : 'example.com' } )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. send ( ) ;
{
type : 'ping/icmp' ,
status : 'reply' ,
host : 'example.com' ,
ip : '93.184.215.14' ,
ips : [ '93.184.215.14' , '2606:2800:021f:cb07:6820:80da:af6b:8b2c' ] ,
time : 130 ,
ttl : 128 ,
bytes : 32 ,
reply : {
source : '93.184.216.34' ,
type : 0 ,
code : 0 ,
typestr : 'ECHO_REPLY' ,
codestr : 'NO_CODE' ,
body : '767284c4'
}
}
// ICMP ping to example.com using ttl = 10
new pingus . PingICMP ( { host : 'example.com' , ttl : 10 } )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. send ( ) ;
{
type : 'ping/icmp' ,
status : 'exception' ,
host : 'example.com' ,
ip : '93.184.215.14' ,
ips : [ '93.184.215.14' , '2606:2800:021f:cb07:6820:80da:af6b:8b2c' ] ,
time : 133 ,
ttl : 10 ,
bytes : 32 ,
reply : {
source : '152.195.76.133' ,
type : 11 ,
code : 0 ,
typestr : 'TIME_EXCEEDED' ,
codestr : 'NO_CODE' ,
body : ']8X"bx00CQx00x00x00x00'
}
}
// Traceroute to example.com
new pingus . PingICMP ( { host : 'example.com' , timeout : 500 } )
. on ( 'result' , ( result ) => {
console . log ( result . toPrimitiveJSON ( ) ) ;
} )
. on ( 'error' , ( err , result ) => {
throw err ;
} )
. traceroute ( ) ;
{
type : 'ping/icmp/traceroute' ,
status : 'finish' ,
host : 'example.com' ,
ip : '93.184.215.14' ,
ips : [ '93.184.215.14' , '2606:2800:021f:cb07:6820:80da:af6b:8b2c' ] ,
time : 7614 ,
ttl : 128 ,
bytes : 32 ,
hops : [
{
status : 'time_exceeded' ,
ip : '172.19.80.1' ,
ttl : 1 ,
rtt : { min : 0 , max : 1 , avg : 1 }
} ,
{
status : 'time_exceeded' ,
ip : '172.30.1.254' ,
ttl : 2 ,
rtt : { min : 0 , max : 1 , avg : 1 }
} ,
{
status : 'timeout' ,
ip : null ,
ttl : 3 ,
rtt : { min : 2001 , max : 2002 , avg : 2002 }
} ,
{
status : 'time_exceeded' ,
ip : '112.188.59.77' ,
ttl : 4 ,
rtt : { min : 2 , max : 3 , avg : 3 }
} ,
{
status : 'time_exceeded' ,
ip : '112.188.53.13' ,
ttl : 5 ,
rtt : { min : 1 , max : 2 , avg : 2 }
} ,
{
status : 'time_exceeded' ,
ip : '112.174.47.177' ,
ttl : 6 ,
rtt : { min : 7 , max : 8 , avg : 8 }
} ,
{
status : 'time_exceeded' ,
ip : '112.174.91.130' ,
ttl : 7 ,
rtt : { min : 7 , max : 8 , avg : 8 }
} ,
{
status : 'time_exceeded' ,
ip : '112.174.87.102' ,
ttl : 8 ,
rtt : { min : 129 , max : 130 , avg : 130 }
} ,
{
status : 'time_exceeded' ,
ip : '206.72.210.112' ,
ttl : 9 ,
rtt : { min : 127 , max : 128 , avg : 128 }
} ,
{
status : 'time_exceeded' ,
ip : '152.195.76.151' ,
ttl : 10 ,
rtt : { min : 132 , max : 134 , avg : 133 }
} ,
{
status : 'reply' ,
ip : '93.184.215.14' ,
ttl : 11 ,
rtt : { min : 126 , max : 126 , avg : 126 }
}
]
}