Ein einfaches Ping-Tool. Unterstützt TCP/UDP/ICMP-Protokoll.
Pingus kann...
Senden Sie eine ICMP-Echo-Anfrage und eine TTL-Traceroute.
Senden Sie Ping, scannen Sie an TCP-/UDP-Ports und erfassen Sie Banner.
Senden Sie ein magisches Paket (Wake on LAN) mit UDP-Ping.
pingus.Ping
'ready'
'result'
'error'
ping.send()
pingus.PingTCP
Erweitert: pingus.Ping
new PingTCP(options)
pingtcp.send()
pingtcp.scan()
pingus.PingUDP
Erweitert: pingus.Ping
new PingUDP(options)
pingudp.send()
pingudp.scan()
pingus.PingICMP
Erweitert: pingus.Ping
new PingICMP(options)
pingicmp.send()
pingicmp.traceroute()
Callback
oder 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
Wenn während der Installation ein Fehler auftritt, kann dies an einem Installationsfehler der folgenden Pakete liegen.
Es kann durch die Installation des GCC-Compilers behoben werden.
Unter Ubuntu:
sudo apt-get install -y build-essential
Unter Windows:
Installieren Sie Visual Studio
einschließlich der Desktop development with C++
Workload.
// 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
ist EventEmitter
mit den folgenden Ereignissen:
'ready'
result
<Object>
Wird ausgegeben, wenn Sie bereit sind (DNS auflösen, Bogon-IP filtern), um einen Ping nach dem Aufruf von ping.send()
zu senden.
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>
Ergebnis der Ping-Daten.
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>
Wird ausgegeben, wenn ein Fehler auftritt. result
enthält die letzte Anweisung vor dem Auftreten des Fehlers und den Fehlercode.
ping.send()
Ping senden. Einige Beispiele finden Sie unter Verwendung
pingus.PingTCP
Erweitert: pingus.Ping
Klasse für TCP-Ping.
pingus.PingTCP
ist eine Art von pingus.Ping
new PingTCP(options)
options
<Object>
host
<string>
Ziel-Hostnamen (Domäne) oder IP-Adresse festlegen.port
<number>
Zielport festlegen, wenn pingtcp.send()
verwendet wird. Standard: 80
ports
<Array>
| <string>
Zielports festlegen, wenn pingtcp.scan()
verwendet wird. Verwenden Sie ein Array von Portnummern oder Abfragezeichenfolgen. Siehe Beispiel.timeout
<number>
Timeout festlegen. Standard: 2000
resolveDNS
<boolean>
DNS- A
und AAAA
Einträge auflösen, wenn host
eine Domänenadresse ist. Standard: true
dnsServer
<string>
DNS-Server zum Auflösen von DNS-Einträgen festlegen.filterBogon
<boolean>
Bogon-IP-Adresse im host
filtern. Standard: 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()
Siehe ping.send()
. Einige Beispiele im Abschnitt „Verwendung“.
pingtcp.scan()
Scannen Sie Ports mit TCP-Ping. Ergebnis bei Ereignis zurückgeben: 'result'
. Einige Beispiele finden Sie unter Verwendung.
pingus.PingUDP
Erweitert: pingus.Ping
Klasse für UDP-Ping.
pingus.PingUDP
ist eine Art von pingus.Ping
new PingUDP(options)
options
<Object>
host
<string>
Ziel-Hostnamen (Domäne) oder IP-Adresse festlegen.port
<number>
Zielport festlegen, wenn pingudp.send()
verwendet wird. Standard: 68
ports
<Array>
| <string>
Zielports festlegen, wenn pingudp.scan()
verwendet wird. Verwenden Sie ein Array von Portnummern oder Abfragezeichenfolgen. Identisch mit PingTCP. Siehe Beispiel.buffer
<Buffer>
Puffer beim Senden auf angeschlossenem UDP-Ping-Socket festlegen.body
<string>
Legt den Text fest, wenn das Senden über einen angeschlossenen UDP-Ping-Socket erfolgt. Wird ignoriert, wenn buffer
festgelegt sind.bytes
<number>
Legt die zufällige Bytelänge fest, wenn sie über einen angeschlossenen UDP-Ping-Socket gesendet wird. Wird ignoriert, wenn body
festgelegt sind. Standard: 32
timeout
<number>
Timeout festlegen. Standard: 2000
resolveDNS
<boolean>
DNS- A
und AAAA
Einträge auflösen, wenn host
eine Domänenadresse ist. Standard: true
dnsServer
<string>
DNS-Server zum Auflösen von DNS-Einträgen festlegen.filterBogon
<boolean>
Bogon-IP-Adresse im host
filtern. Standard: true
pingudp.send()
Siehe ping.send()
. Einige Beispiele im Abschnitt „Verwendung“.
pingudp.scan()
Ähnlich mit pingtcp.scan()
.
Scannen Sie Ports mit UDP-Ping. Ergebnis bei Ereignis zurückgeben: 'result'
. Einige Beispiele finden Sie unter Verwendung.
pingus.PingICMP
Erweitert: pingus.Ping
Klasse für ICMP-Ping.
pingus.PingICMP
ist eine Art von pingus.Ping
new PingICMP(options)
options
<Object>
host
<string>
Ziel-Hostnamen (Domäne) oder IP-Adresse festlegen.ttl
<number>
Ttl festlegen. Standard: 128
ttln
<number>
Start-Ttl festlegen, wenn pingicmp.traceroute()
verwendet wird. Standard: 1
ttlx
<number>
Legt den maximalen TTL fest, wenn pingicmp.traceroute()
verwendet wird. Standard: 64
timeout
<number>
Timeout festlegen. Standard: 2000
timeoutx
<number>
Legt den maximalen Timeout-Stack fest, wenn pingicmp.traceroute()
verwendet wird. Standard: 8
resolveDNS
<boolean>
DNS- A
und AAAA
Einträge auflösen, wenn host
eine Domänenadresse ist. Standard: true
dnsServer
<string>
DNS-Server zum Auflösen von DNS-Einträgen festlegen.filterBogon
<boolean>
Bogon-IP-Adresse im host
filtern. Standard: true
pingicmp.send()
Siehe ping.send()
. Einige Beispiele im Abschnitt „Verwendung“.
pingicmp.traceroute()
Führen Sie Traceroute aus. Einige Beispiele im Abschnitt „Verwendung“.
Callback
oder Promise
( async/await
)Beispiele finden Sie unter Ping-Sendestile.
pingus.tcp(options[, callback])
TCP-Ping senden.
pingus.tcpscan(options[, callback])
Scannen Sie Ports mit TCP-Ping.
pingus.udp(options[, callback])
UDP-Ping senden.
pingus.udpscan(options[, callback])
Scannen Sie Ports mit UDP-Ping.
pingus.wol(mac, options[, callback])
mac
<string>
Ziel-MAC-Adresse festlegen.options
<Object>
Identisch mit Optionen des new PingUDP(options)
Senden Sie einen Magic Packet-UDP-Ping, um die WOL-Funktion zu nutzen.
pingus.icmp(options[, callback])
ICMP-Ping senden.
pingus.traceroute(options[, callback])
Führen Sie Traceroute aus.
ESM (TypeScript)
import pingus from 'pingus' ;
CJS
const pingus = require ( 'pingus' ) ;
Class
erweitert 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
verwenden // TCP ping to localhost:80
pingus . tcp ( { host : 'localhost' } , ( err , result ) => {
if ( err ) {
throw err ;
}
console . log ( result ) ;
} ) ;
Promise
verwenden // 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 }
}
]
}