0


扫描网络端口

一、实验目的

 本次实验通过在理解扫描器原理的基础上,利用Java开发环境来编程实现一款简易的扫描器,熟悉主机及端口扫描工具。

二、实验内容

  编写程序扫描网络端口,查看状态--关闭或者开启,同时要设置端口关闭或者开启功能,并且能够扫描到开启或者关闭的端口。

三、实验原理

1.端口介绍

  在Internet上,按照协议类型分类,端口被分为TCP端口和UDP端口两类,虽然他们都用正整数标识,但这并不会引起歧义,比如TCP的80端口和UDP的80端口,因为数据报在标明端口的同时,还将标明端口的类型。 

从端口的分配来看,端口被分为固定端口和动态端口两大类(一些教程还将极少被用到的高端口划分为第三类:私有端口):

固定端口(0-1023):使用集中式管理机制,即服从一个管理机构对端口的指派,这个机构负责发布这些指派。由于这些端口紧绑于一些服务,所以我们会经常扫描这些端口来判断对方是否开启了这些服务,如TCP的21(ftp),80(http),139(netbios),UDP的7(echo),69(tftp)等等一些大家熟知的端口;

动态端口(1024-49151):这些端口并不被固定的捆绑于某一服务,操作系统将这些端口动态的分配给各个进程,同一进程两次分配有可能分配到不同的端口。不过一些应用程序并不愿意使用操作系统分配的动态端口,他们有其自己的“商标性”端口,如oicq客户端的 4000端口,木马冰河的7626端口等都是固定而出名的。

**2.**常见的扫描类型

端口扫描分类

四、实验步骤

(1)输入想要扫描的IP地址和想要打开的端口号范围,显示出扫描端口的开关情况。

(2)输入想要开启的端口号,这里打开29号端口。

(3)在cmd中输入netstat -a 命令查看:29号端口是开启的。

(4)关闭29号端口,显示关闭完成。

(5)在cmd中输入netstat -a 命令查看:已查询不到29号端口,29号端口是关闭的。

五、实验代码

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.Inet4Address;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.Scanner;

public class ScanPort {
    public static void main(String[] args) throws Exception {
        
        Scanner sc=new Scanner(System.in);
        System.out.print("请输入你想要扫描的ip地址:");
        String yid=sc.next();
        System.out.print("请输入超时时间:");
        int timeout=sc.nextInt();
        System.out.print("请输入起始端口号:");
        int i=sc.nextInt();
        System.out.print("请输入最后端口号:");
        int k=sc.nextInt();     
        InetAddress ip=InetAddress.getByName(yid);
        System.out.println("开始扫描:");
        for(;i<=k;i++) {
            try {
                    Socket socket=new Socket();
                    //实现与端口连接
                    // 设置连接超时时间
                    socket.connect(new InetSocketAddress(ip, i), timeout);
                    //判断端口连接状态
                    if(socket.isBound()) System.out.println(i+"端口 open");
                    //if(!socket.isBound()) System.out.println(i+"端口 close");
                    socket.close();
                } catch (Exception e) { 
                System.out.println(i+"端口 close");
            }   
        }
        System.out.println("结束扫描");
        System.out.print("请输入想开启的端口号:");
        int openport=sc.nextInt();      
        ServerSocket server = new ServerSocket(openport);
        for(i=0;i<=k;i++) {
            try {
                    Socket socket=new Socket();
                    //实现与端口连接
                    // 设置连接超时时间
                    socket.connect(new InetSocketAddress(ip, i), timeout);
                    //判断端口连接状态
                    if(socket.isBound()) System.out.println(i+"端口 open");
                    //if(!socket.isBound()) System.out.println(i+"端口 close");
                    socket.close();
                } catch (Exception e) { 
                System.out.println(i+"端口 close");
            }   
        }
        System.out.print("请输入想关闭的端口号:");
        int closeport=sc.nextInt();
        ServerSocket server1;
        if(closeport==openport)
            server.close();
        else {
            server1 = new ServerSocket(closeport);
            server1.close();
        }
        System.out.print("关闭完成");
    }
}
标签: 网络安全

本文转载自: https://blog.csdn.net/capture3333/article/details/125668908
版权归原作者 钻仰弥坚 所有, 如有侵权,请联系我们删除。

“扫描网络端口”的评论:

还没有评论