局域网在线IP检测
写了一个局域网在线ip检测工具这段代码的主要功能是通过多线程方式扫描一个局域网内的 IP 地址,检测哪些 IP 地址是在线的。
1. **线程数量和步长**:
```python
num_threads = 200# 可以根据需要调整线程数量
step = (end_ip - start_ip + 1) // num_threads
```
- `num_threads` 定义了将要使用的线程数量,这里设置为 200。
- `step` 计算出每个线程需要扫描的 IP 范围的大小,通过 `(end_ip - start_ip + 1) // num_threads` 计算得到。
2. **记录开始时间**:
```python
start_time = time.time()# 记录开始时间
```
- 通过 `time.time()` 记录当前时间,用于计算扫描所花费的总时间。
3. **创建并启动线程**:
```python
for i in range(num_threads):
s = start_ip + i * step
e = min(start_ip + (i + 1) * step - 1, end_ip)
t = threading.Thread(target=scan_range, args=(s, e))
threads.append(t)
t.start()
```
- 通过循环创建多个线程。每个线程负责扫描一个 IP 范围。
- `s` 和 `e` 分别代表当前线程要扫描的起始和结束 IP 地址。
- 使用 `threading.Thread` 创建线程,并将扫描函数 `scan_range` 作为目标,传递起始和结束 IP 作为参数。
- 将线程添加到 `threads` 列表中,并调用 `t.start()` 启动线程。
4. **等待所有线程结束**:
```python
for t in threads:
t.join()
```
- 这个循环确保主线程会等待所有的工作线程 `t` 完成后再继续执行。`t.join()` 阻塞主线程,直到 `t` 线程结束。
5. **记录结束时间和计算耗时**:
```python
end_time = time.time()# 记录结束时间
elapsed_time = end_time - start_time
elapsed_time_formatted = "{:.2f}".format(elapsed_time)# 格式化为小数点后两位
```
- 记录结束时间后,通过简单的减法计算出整个扫描过程的耗时。
- `elapsed_time_formatted` 用于将耗时格式化为小数点后两位的字符串。
6. **打印扫描结果**:
```python
print(f"扫描完成,总共用时: {elapsed_time_formatted} 秒")
return online_ips
```
- 打印扫描完成的信息及所耗的时间。
- 最后返回在线的 IP 地址列表 `online_ips`。
这段代码利用多线程提高 IP 扫描效率,适用于局域网的在线状态检测,并统计出扫描所用的时间。
页:
[1]