用Java实现的多线程扫描IP程序

import java.net.*;
import java.io.*;
import java.util.LinkedList;
import java.util.Queue;
import java.util.concurrent.*;

public class Main {
    public static void main(String[] args) {
        PingTester tester = new PingTester();
        tester.startPing();
    }
}

class PingTester {
    private Queue<String> allIp;
    private int fetchedNum = 0; // 已经取得的任务数量,每次从队列中取一个ip就加1

    public PingTester() {
        // 首先创建一个队列用于存储所有ip地址
        allIp = new LinkedList<String>();
        for (int i = 0; i < 10; i++) {
            //allIp.offer("192.168.9." + i);
            for (int j = 0; j < 256; j++) {
                allIp.offer("192.168."+i+"."+j);
            }
        }
    }

    public void startPing() {
        // 创建一个线程池,多个线程同时跑
        int threadNum = 1000;
        ExecutorService executor = Executors.newFixedThreadPool(threadNum);
        for (int i = 0; i < threadNum; i++) {
            executor.execute(new PingRunner());
        }
        executor.shutdown();
        try {
            while (!executor.isTerminated()) {
                Thread.sleep(100);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("Fetched num is "+fetchedNum);
    }

    private class PingRunner implements Runnable {
        private String taskIp = null;
        @Override
        public void run() {
            try {
                while ((taskIp = getIp()) != null) {
                    InetAddress addr = InetAddress.getByName(taskIp);
                    if (addr.isReachable(5000)) {
                        System.out.println("host ["+taskIp+"] is reachable");
                    } else {
                        System.out.println("host ["+taskIp+"] is not reachable");
                    }
                }
            } catch (SocketException e) {
                System.out.println("host ["+taskIp+"] permission denied");
            } catch (Exception e) {
                System.out.println("---------------------------------------------"+taskIp);
                e.printStackTrace();
            }
        }

        public String getIp() {
            String ip = null;
            synchronized (allIp) {
                ip = allIp.poll();
            }
            if (ip != null) {
                fetchedNum++;
            }
            return ip;
        }
    }
}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 我可以回答这个问题。基于多线程的端口扫描程序可以使用 Java 编写。通过创建多个线程,每个线程负责扫描一定范围的端口,可以大大提高扫描速度。同时,需要注意线程安全问题,避免多个线程同时访问同一个资源导致的竞争问题。 ### 回答2: 基于多线程的端口扫描程序可以使用Java语言实现。下面是一个简单的实现示例: ```java import java.net.*; import java.util.concurrent.*; public class PortScanner { public static void main(String[] args) { String host = "localhost"; //要扫描的主机 int startPort = 1; //起始端口号 int endPort = 65535; //结束端口号 int timeout = 100; //超时时间(毫秒) int numThreads = 100; //线程数 ExecutorService executor = Executors.newFixedThreadPool(numThreads); for (int port = startPort; port <= endPort; port++) { executor.submit(new PortScanTask(host, port, timeout)); } executor.shutdown(); } private static class PortScanTask implements Runnable { private String host; private int port; private int timeout; public PortScanTask(String host, int port, int timeout) { this.host = host; this.port = port; this.timeout = timeout; } @Override public void run() { try { Socket socket = new Socket(); socket.connect(new InetSocketAddress(host, port), timeout); System.out.println("端口 " + port + " 开放"); socket.close(); } catch (Exception ex) { //捕获异常说明端口关闭或无法连接 } } } } ``` 以上代码创建了一个ExecutorService线程池来管理线程。然后,使用for循环遍历指定范围内的端口号,并提交任务给线程池。每个任务通过Socket连接检查对应端口是否开放。如果连接成功,则说明端口开放,打印相关信息。如果连接失败,则说明端口关闭或无法连接。 在实际使用中,可以根据需求调整主机地址、起始和结束端口号、超时时间以及线程数等参数。此示例只是一个基本的多线程端口扫描程序,可以根据实际需求进行优化和扩展。 ### 回答3: 基于多线程的端口扫描程序是使用Java编写的一种网络安全工具。它通过同时运行多个线程来扫描一个或多个目标主机上的开放端口。以下是一个简单的实现示例: 首先,我们需要创建一个扫描器类,负责实现端口扫描的逻辑。该类需要继承Thread类,并重写run()方法,用于执行具体的扫描操作。在run()方法中,我们可以使用Socket类来建立与目标主机的连接,并检查特定端口是否开放。 接下来,我们需要创建一个扫描器管理类,用于创建和管理扫描器的线程。在该类中,我们可以定义一个线程池,用于存储所有扫描器线程的引用。线程池的大小可以根据需求进行调整。在执行扫描操作之前,我们需要通过调用线程池的execute()方法来启动线程。 在执行端口扫描之前,我们需要从用户那里获得目标主机的IP地址和要扫描的端口范围。可以使用Scanner类或命令行参数来实现这一点。 当线程启动后,每个线程将尝试连接目标主机的一个端口。如果连接成功,则说明该端口是开放的。程序可以通过输出结果或记录到文件中来显示或存储这些信息。 扫描完成后,我们需要关闭所有线程,并进行必要的清理操作。 由于端口扫描属于网络安全领域,使用这种多线程扫描程序需要遵循合适的法律和道德规范。在实际使用中,还需要考虑并发访问控制、资源管理和错误处理等方面的问题。 在实际应用中,还可以对扫描程序进行进一步的改进,例如添加超时检测、扫描速度控制和结果过滤等功能,以提高性能和可靠性。 总结来说,基于多线程的端口扫描程序是一个利用Java多线程技术实现的网络安全工具,可以快速扫描目标主机上的开放端口,并提供实时结果反馈。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值