有人可以帮助我使用命令行检查具有特定IP地址范围的端口扫描程序。如何确保端口扫描具有该IP的范围。
args [0]和args [1]用于IP地址范围,而args [2]和args [3]用于端口扫描程序。
例如我运行“java Test 1.1.1.1 5 0 10” 程序将检查端口0-10上的IP从1.1.1.1到1.1.1.5
这是我的代码:
import java.util.concurrent.*;
import java.util.*;
import java.net.*;
// source http://stackoverflow.com/questions/11547082/fastest-way-to-scan-ports-with-java
public class Test
{
public static void main(String [] args) throws Exception
{
final ExecutorService es = Executors.newFixedThreadPool(20);
int bRange = 0; //Declare String called bRange with initial value of 0.
int eRange = 0; //Declare String called eRange with initial value of 0.
final int timeout = 200;
//byte[] ipAddr = InetAddress.getByName(args[0]).getAddress();
//byte[] ipAddr1 = InetAddress.getByName(args[1]).getAddress();
String ipAddr = args[0];
String ipAddr1 = args[1];
if (args.length != 3)
{
try
{
bRange = Integer.parseInt(args[2]); //Assign value of second argument to bRange.
eRange = Integer.parseInt(args[3]); //Assign value of third argument to eRange.
}
catch(NumberFormatException E) //If user enter invalid data.
{
System.out.println("You did not enter a valid number for arguments 2 and 3. Please try again with valid Integers.");
System.exit(0);
}
boolean fcheck = true; //DEBUG ONLY CAN DELETE
final List<Future<Boolean>> futures = new ArrayList<>();
ArrayList<Integer> portRange = new ArrayList<Integer>((eRange - bRange)); //Declare an ArrayList of Integer values called portRange and set its initial size.
//For loop to randomize scans.
for(int port = bRange; port <= eRange; port++)
{
portRange.add(port);
//Use ArrayList of portRange and shuffle to go through each port number once.
Collections.shuffle(portRange); //Shuffle portRange.
int size = portRange.size(); //Declare Integer called size and assign value of portRange ArrayList size value.
int randPort = portRange.get(size-1); //Assign the last index of portRange ArrayList to Integer variable randPort.
System.out.println(randPort); //Show all the ports
//int randTimeout = randInt(30, 2000); //Assign random value to randTimeout by running method randInt(). PartD
futures.add(portIsOpen(es, ipAddr, randPort, timeout));
portRange.remove(size - 1); //Remove last element in portRange ArrayList.
}
es.shutdown(); //Tell the executor service that it can't accept new tasks, but the already submitted tasks continue to run.
int openPorts = 0; //Declare Integer called openPorts and assign value of 0.
for(final Future<Boolean> f : futures)
{
if(f.get())
{
openPorts++;
}
}
System.out.println("There are " + openPorts + " open ports on host " + ipAddr + " to " + ipAddr1 + " probed with a timeout of " + timeout + "ms");
//Print statement show how many ports open based on the particular IP Address and the timeout.
}
else
{
System.out.println("Wrong number of arguments");
System.out.println("Please try again");
}
}
public static Future<Boolean> portIsOpen(final ExecutorService es, final String ipAddr, final int port, final int timeout)
{
return es.submit(new Callable<Boolean>()
{
@Override public Boolean call()
{
try //Try block, each time the For loop increments the Try block gets invoked.
{
Socket socket = new Socket(); //The Try block creates an instance of the Socket Class.
socket.connect(new InetSocketAddress(ipAddr, port), timeout); //Create a stream socket and connects it to specified port number at the specified IP Address.
socket.close(); //Close the socket connection.
System.out.println("open port found " + port); //Result show how many ports are open.
return true;
}
catch (Exception ex)
{
return false;
}
}
});
}
}
答案 0 :(得分:1)
我想,使用通常的CIDR标记确定ip-addresses范围要好得多。在这种情况下,您需要使用一个额外的参数,如1.1.1.1/29
,这意味着IP地址范围从1.1.1.1到1.1.1.6,1.1.1.7是广播地址。您可以使用Apache Commons Net类SubnetUtils来确定范围并获取所有包含的地址:
public static void main(String[] args) {
String subnet = "1.1.1.1/29";
SubnetUtils utils = new SubnetUtils(subnet);
String[] addresses = utils.getInfo().getAllAddresses();
for (String ip : addresses) {
System.out.println(ip);
}
}
但是现在看来,你的例子只检查指定范围的第一个地址,因为你没有提供任何逻辑来迭代你给出的地址范围。
因此,如果您仍希望以前的方式设置范围,则需要将范围表示法转换为具体地址列表,然后在此列表上添加一个额外的循环,并将此循环包含在端口上的循环中。 / p>
要获得此列表,您可以使用getIpList
方法中的逻辑,只需要提供例外处理等:
public static List<String> getIpList(String startIp, int number) {
List<String> result = new ArrayList<>();
String currentIp = startIp;
for (int i = 0; i < number; i++) {
String nextIp = nextIpAddress(currentIp);
result.add(nextIp);
currentIp = nextIp;
}
return result;
}
public static final String nextIpAddress(final String input) {
final String[] tokens = input.split("\\.");
if (tokens.length != 4)
throw new IllegalArgumentException();
for (int i = tokens.length - 1; i >= 0; i--) {
final int item = Integer.parseInt(tokens[i]);
if (item < 255) {
tokens[i] = String.valueOf(item + 1);
for (int j = i + 1; j < 4; j++) {
tokens[j] = "0";
}
break;
}
}
return new StringBuilder()
.append(tokens[0]).append('.')
.append(tokens[1]).append('.')
.append(tokens[2]).append('.')
.append(tokens[3])
.toString();
}
然后你可以获得该范围内的IP列表,添加一个循环:
List<String> ipRange = getIpList(ipAddr, ipAddr1);
for(String ipaddr : ipRange) {
for (int port = bRange; port <= eRange; port++) {
portRange.add(port);
//Use ArrayList of portRange and shuffle to go through each port number once.
Collections.shuffle(portRange); //Shuffle portRange.
int size = portRange.size(); //Declare Integer called size and assign value of portRange ArrayList size value.
int randPort = portRange.get(size - 1); //Assign the last index of portRange ArrayList to Integer variable randPort.
System.out.println(randPort); //Show all the ports
//int randTimeout = randInt(30, 2000); //Assign random value to randTimeout by running method randInt(). PartD
futures.add(portIsOpen(es, ipaddr, randPort, timeout));
portRange.remove(size - 1); //Remove last element in portRange ArrayList.
}
}