0.2.1 |
|
---|---|
0.2.0 |
|
#21 in #port-scan
在5个crate中使用了(直接使用4个)
22KB
492 代码行
nerve
安全扫描库,旨在轻量快速。
nerve
提供用于网络/安全扫描的跨平台API
(用于安全测试、网络管理、评估)
使用Rust。
目前处于alpha阶段。
特性
- 端口扫描
- 主机扫描
- URI扫描
- 域名扫描
用法
将nerve
添加到您的依赖中
[dependencies]
nerve = "0.2.1"
- 提供每个功能的结构体
PortScanner
HostScanner
UriScanner
DomainScanner
- 每个结构的简单用法
::new()
返回一个Scanner。- 设置扫描器(见示例)
::run_scan()
使用当前设置运行扫描。- 结果存储在
::scan_result
::get_result()
返回一个扫描结果。
示例
端口扫描示例
extern crate nerve_port;
use nerve_port::PortScanner;
use nerve_port::PortScanType;
use nerve_port::ScanStatus;
use std::time::Duration;
fn main() {
let mut port_scanner = match PortScanner::new(None, None) {
Ok(scanner) => (scanner),
Err(e) => panic!("Error creating scanner: {}", e),
};
port_scanner.set_target_ipaddr("192.168.1.92");
port_scanner.set_range(1, 1000);
port_scanner.set_scan_type(PortScanType::SynScan);
port_scanner.set_timeout(Duration::from_millis(10000));
port_scanner.run_scan();
let result = port_scanner.get_result();
print!("Status: ");
match result.scan_status {
ScanStatus::Done => {println!("Normal end")},
ScanStatus::Timeout => {println!("Timed out")},
_ => {println!("Error")},
}
println!("Open Ports:");
for port in result.open_ports {
println!("{}", port);
}
println!("Scan Time: {:?}", result.scan_time);
}
更多详情请见示例
支持的平台
- Linux
- macOS(OS X)
- Windows
附加说明
此库需要创建原始套接字的能力。需要以root用户权限执行。
依赖项
~1.1–2.1MB
~39K SLoC