掃描整個網段的多執行緒程式(轉)
掃描整個網段的多執行緒程式(轉)[@more@]作者:steeven
email:
掃描500個IP10秒鐘左右, 一個IP等待0.3秒
說來慚愧, 我覺得是用java寫的過程程式設計, 少貼一點僅供參考:
package steeven;
import java.sql.*;
import java.io.*;
import java.util.*;
import java.text.*;
import javax.servlet.http.*;
public class Ip extends Common implements Runnable{
public String ip; // IP, 使用者名稱, 主機名
ResultSet list; // 分頁顯示的記錄集
public Ip cur; // 分頁顯示的當前記錄
static public Hashtable ping = new Hashtable(); //ping 後的結果集
static int threadCount = 0; //當前執行緒的數量, 防止過多執行緒摧毀電腦
public Ip() {}
public Ip(String ip){
this.ip=ip;
Thread r = new Thread(this);
r.start();
}
public static void Ping(String ip) throws Exception{
//最多30個執行緒
while(threadCount>30)
Thread.sleep(50);
threadCount +=1;
Ip p = new Ip(ip);
}
public void PingAll() throws Exception{
threadCount =0;
ping = new Hashtable();
while(next()) //next()對所有區域網Ip放到cur
Ping(cur.ip);
//等著所有Ping結束
while(threadCount>0)
Thread.sleep(50);
}
public void run(){
try{
Process p= Runtime.getRuntime().exec ("ping "+ip+ " -w 300 -n 1");
InputStreamReader ir = new InputStreamReader(p.getInputStream());
LineNumberReader input = new LineNumberReader (ir);
//讀取結果行
for (int i=1 ; i<7; i++)
input.readLine();
String line= input.readLine();
if (line.length()<17 || line.substring(8,17).equals("timed out"))
ping.put(ip,new Boolean(false));
else
ping.put(ip,new Boolean(true));
//執行緒結束
threadCount -= 1;
}catch (IOException e){}
}
public static void main(String[] args) throws Exception{
Ip ip= new Ip();
ip.PingAll();
java.util.Enumeration key = ping.keys();
String k;
while((k = (String)key.nextElement()) != null)
System.out.println(k+": "+ping.get(k));
}
}
1. 利用Ping比較愚蠢, 但是相對簡單些
2. 如果Ping 成功後, 用nbtstat還可以得到主機名, 當前使用者名稱, MAC地址...一切盡在掌握中 :)
email:
掃描500個IP10秒鐘左右, 一個IP等待0.3秒
說來慚愧, 我覺得是用java寫的過程程式設計, 少貼一點僅供參考:
package steeven;
import java.sql.*;
import java.io.*;
import java.util.*;
import java.text.*;
import javax.servlet.http.*;
public class Ip extends Common implements Runnable{
public String ip; // IP, 使用者名稱, 主機名
ResultSet list; // 分頁顯示的記錄集
public Ip cur; // 分頁顯示的當前記錄
static public Hashtable ping = new Hashtable(); //ping 後的結果集
static int threadCount = 0; //當前執行緒的數量, 防止過多執行緒摧毀電腦
public Ip() {}
public Ip(String ip){
this.ip=ip;
Thread r = new Thread(this);
r.start();
}
public static void Ping(String ip) throws Exception{
//最多30個執行緒
while(threadCount>30)
Thread.sleep(50);
threadCount +=1;
Ip p = new Ip(ip);
}
public void PingAll() throws Exception{
threadCount =0;
ping = new Hashtable();
while(next()) //next()對所有區域網Ip放到cur
Ping(cur.ip);
//等著所有Ping結束
while(threadCount>0)
Thread.sleep(50);
}
public void run(){
try{
Process p= Runtime.getRuntime().exec ("ping "+ip+ " -w 300 -n 1");
InputStreamReader ir = new InputStreamReader(p.getInputStream());
LineNumberReader input = new LineNumberReader (ir);
//讀取結果行
for (int i=1 ; i<7; i++)
input.readLine();
String line= input.readLine();
if (line.length()<17 || line.substring(8,17).equals("timed out"))
ping.put(ip,new Boolean(false));
else
ping.put(ip,new Boolean(true));
//執行緒結束
threadCount -= 1;
}catch (IOException e){}
}
public static void main(String[] args) throws Exception{
Ip ip= new Ip();
ip.PingAll();
java.util.Enumeration key = ping.keys();
String k;
while((k = (String)key.nextElement()) != null)
System.out.println(k+": "+ping.get(k));
}
}
1. 利用Ping比較愚蠢, 但是相對簡單些
2. 如果Ping 成功後, 用nbtstat還可以得到主機名, 當前使用者名稱, MAC地址...一切盡在掌握中 :)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10617731/viewspace-958487/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 多執行緒掃描資料夾耗時方法分析執行緒
- 基於python編寫一個簡單的多執行緒埠掃描指令碼Python執行緒指令碼
- Python——程式、執行緒、協程、多程式、多執行緒(個人向)Python執行緒
- 執行緒以及多執行緒,多程式的選擇執行緒
- 多執行緒,多程式執行緒
- 多執行緒------執行緒與程式/執行緒排程/建立執行緒執行緒
- Python 多執行緒多程式Python執行緒
- Android中的多程式、多執行緒Android執行緒
- Python的多程式和多執行緒Python執行緒
- 【java】【多執行緒】程式、執行緒的基本概念(1)Java執行緒
- PHP 的多程式與執行緒PHP執行緒
- JS引擎執行緒的執行過程的三個階段JS執行緒
- python多程式取代多執行緒的探究Python執行緒
- [譯] Python 的多執行緒與多程式Python執行緒
- [短文速讀 -5] 多執行緒程式設計引子:程式、執行緒、執行緒安全執行緒程式設計
- pytest(13)-多執行緒、多程式執行用例執行緒
- 多執行緒程式設計基礎(一)-- 執行緒的使用執行緒程式設計
- 多執行緒和多執行緒同步執行緒
- 多執行緒,到底該設定多少個執行緒?執行緒
- 多執行緒程式是如何執行程式碼的?執行緒行程
- Python 多執行緒及程式Python執行緒
- 玩轉java多執行緒 之多執行緒基礎 執行緒狀態 及執行緒停止實戰Java執行緒
- 執行緒與多執行緒執行緒
- 多執行緒【執行緒池】執行緒
- 多執行緒--執行緒管理執行緒
- 多執行緒執行任務時,某個執行緒拋異常,如何讓程式立即退出執行緒
- InsightScan:Python多執行緒Ping/埠掃描 + HTTP服務/APP 探測,可生成Hydra用的IP列表Python執行緒HTTPAPP
- pytest多程式/多執行緒執行測試用例執行緒
- 入門python多執行緒/多程式Python執行緒
- 多執行緒程式設計基礎(二)-- 執行緒池的使用執行緒程式設計
- 執行緒和程式基礎以及多執行緒的基本使用(iOS)執行緒iOS
- 三個執行緒迴圈列印123-多執行緒執行緒
- Java多執行緒-程式執行堆疊分析Java執行緒
- 多執行緒(五)---執行緒的Yield方法執行緒
- 【Java多執行緒】執行緒安全的集合Java執行緒
- Java多執行緒-執行緒池的使用Java執行緒
- 深入淺出Win32多執行緒程式設計--之MFC的多執行緒Win32執行緒程式設計
- Java多執行緒-執行緒中止Java執行緒
- 多執行緒之初識執行緒執行緒