Java 端口扫描器 TCP的实现方法

想必很多朋友都实现过一个简易的聊天室这个功能,其中涉及到Socket套接字这个类,我们通过一个特定的IP以及特定的端口创建一个服务端的套接字(ServerSocket),以此我们聊天个体的套接字(Socket)再与其连接,从而实现连通并通过流来传递信息的聊天室功能。

而端口扫描器所用的知识体系也是基于Socket,相当于我们已经有一个 服务器端的套接字,我们去查看其是否能够连通,即可。


按照上面的思路,我们可能已经有了一个大体的思路:

我们通过建立一个Socket来连接一个要扫描的IP以及PORT,只建立连接不传递数据。

再通过捕捉IOException来检测是否连接成功。

所以大家很快就会有一串如下的实现代码:

static public String ScannerPortisAlive(int port,String HostIP){
        String result="OPEN";       
        try{
            Socket testPortSocket = new Socket(HostIP, port);
            testPortSocket.close();
        }catch (IOException e) {
            result = "CLOSE";
        }
        return result;
    }

但是在我实际测试情况来看,这段代码的执行效率非常低下,问题出在哪里呢? 原来,当端口不通时,Socket会默认等待,所以我们要重新设置连接等待时长。

static public String ScannerPortisAlive(int port){
        String result="OPEN";
        Socket socket=null;
        try{
            socket=new Socket();
            InetAddress ip=InetAddress.getLocalHost();
            SocketAddress address=new InetSocketAddress(ip, port);
            socket.connect(address,100);
            socket.close();
//            Socket testPortSocket = new Socket(HostIP, port);
//            testPortSocket.close();
        }catch (IOException e) {
            result = "CLOSE";
        }
        return result;
    }

除此之外,我们只需要再开一个线程池来处理要处理的端口就可以啦。

笔者实现了一个简单的可用的桌面端口扫瞄器,大家可以用作参考:

Jar可执行程序:https://files.cnblogs.com/files/rekent/Port_Scanner_jar.zip

Source Code:https://files.cnblogs.com/files/rekent/Port_Scanner.zip

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏陈树义

Dubbo配置方式详解

Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是阿里巴巴 SOA 服务化治理方案的核心框架,每天为 2,000+ 个服...

4897
来自专栏Golang语言社区

go http 服务器编程(2)

match 会遍历路由信息字典,找到所有匹配该路径最长的那个。路由部分的代码解释就到这里了,最后回答上面的一个问题:http.HandleFunc 和 Serv...

3154
来自专栏你不就像风一样

基于Netty实现静态web服务器

关于启动类,需要我们做的就是自定义端口以及继承ChannelInitializer类。

1092
来自专栏LEo的网络日志

python i18n实现

3817
来自专栏黑泽君的专栏

linux下vi编辑某文件时,操作出现 错误提示: E325: ATTENTION 2, Found a swap file by the name ".p1.c.swp"

root@iZ2zeeailqvwws5dcuivdbZ:~/1/01/指针# vi p1.c

1.3K1
来自专栏Ceph对象存储方案

源码阅读再来一发:解读RGW中request的处理流程

请求处理流程图 ? 以civetweb为例 1. rgw_main.cc为整个radosgw服务的入口,main()函数中根据在ceph.conf的rgw...

6939
来自专栏个人分享

Spark Netty与Jetty (源码阅读十一)

  spark呢,对Netty API又做了一层封装,那么Netty是什么呢~是个鬼。它基于NIO的服务端客户端框架,具体不再说了,下面开始。

1724
来自专栏chenssy

【追光者系列】HikariCP源码分析之故障检测那些思考 fail fast & allowPoolSuspension

由于时间原因,本文主要内容参考了 https://segmentfault.com/a/1190000013136251,并结合一些思考做了增注。

1762
来自专栏JetpropelledSnake

Python入门之logging模块

本章目录:     一、logging模块简介     二、logging模块的使用     三、通过JSON或者YMAL文件配置logging模块 ====...

36612
来自专栏技术墨客

Spring核心——数据校验

在Java数据校验详解中详细介绍了Java数据校验相关的功能(简称Bean Validation,涵盖JSR-303、JSR-349、JSR-380),本文将在...

1001

扫码关注云+社区

领取腾讯云代金券