写一个TCP端口扫描程序
时间: 2023-05-13 16:05:46 浏览: 88
好的,以下是一个简单的TCP端口扫描程序的代码:
```python
import socket
target = input('请输入要扫描的IP地址:')
port_range = input('请输入要扫描的端口范围(如:1-65535):')
start_port, end_port = port_range.split('-')
start_port = int(start_port)
end_port = int(end_port)
print('开始扫描...')
for port in range(start_port, end_port+1):
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.settimeout(0.1)
result = s.connect_ex((target, port))
if result == 0:
print(f'端口 {port} 开放')
s.close()
print('扫描结束')
```
这个程序可以输入要扫描的IP地址和端口范围,然后扫描这个IP地址上的所有端口,输出哪些端口是开放的。
相关问题
php写一个端口扫描工具
### 回答1:
下面是一个简单的 PHP 端口扫描工具代码:
```
<?php
$host = 'example.com';
$ports = array(21, 22, 80, 443);
foreach ($ports as $port) {
$connection = @fsockopen($host, $port);
if (is_resource($connection)) {
echo '<p>' . $host . ':' . $port . ' ' . '(' . getservbyport($port, 'tcp') . ') is open.</p>';
fclose($connection);
} else {
echo '<p>' . $host . ':' . $port . ' is closed.</p>';
}
}
?>
```
请求将要扫描的主机名称替换为 $host 变量,需要扫描的端口列表替换为 $ports 数组。
使用 @fsockopen() 函数来建立连接, 检查端口是否打开.如果打开, 输出信息并关闭连接。如果关闭,输出相应的信息。
注意: 这是一个简单的代码示例,并不能用于实际的安全评估。
### 回答2:
PHP是一种服务器端脚本语言,通常用于开发Web应用。尽管PHP本身不提供直接的端口扫描功能,但我们可以使用socket和网络相关的函数来实现一个基本的端口扫描工具。
首先,我们需要创建一个函数来扫描指定IP地址的端口。代码示例如下:
```php
function scanPort($ip, $port) {
$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
socket_set_nonblock($socket);
socket_connect($socket, $ip, $port);
$read = [$socket];
$write = [$socket];
$except = null;
if (socket_select($read, $write, $except, 5) == 1) {
$result = "开放";
} else {
$result = "关闭";
}
socket_close($socket);
return $result;
}
```
接下来,我们可以编写一个简单的程序来调用该函数,扫描一系列端口。示例代码如下:
```php
$ip = "127.0.0.1";
$ports = [80, 443, 3306, 8080];
foreach ($ports as $port) {
$result = scanPort($ip, $port);
echo "端口 $port :$result\n";
}
```
在上述代码中,我们指定了要扫描的IP地址和一系列端口。然后,使用foreach循环遍历端口列表,并调用scanPort函数来扫描每个端口。最后,我们将扫描结果打印到屏幕上。
### 回答3:
PHP是一种后端脚本语言,通常用于开发Web应用程序。虽然PHP本身并不是专门用于端口扫描的工具,但我们可以利用其网络功能和函数库来编写一个简单的端口扫描工具。
首先,我们需要用到PHP的网络套接字编程,可以使用socket函数创建一个网络连接。然后,我们可以使用socket_connect函数连接到目标主机的特定端口。
接下来,我们可以通过循环遍历端口范围,并在每个端口上尝试连接。如果连接成功,则说明该端口是开放的;如果连接失败,则说明该端口是关闭的或拒绝连接。
以下是一个简单的PHP端口扫描工具示例代码:
```
<?php
function scanPort($host, $startPort, $endPort)
{
for ($port = $startPort; $port <= $endPort; $port++) {
$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
$result = socket_connect($socket, $host, $port);
if ($result) {
echo "端口 {$port} 开放\n";
} else {
echo "端口 {$port} 关闭\n";
}
socket_close($socket);
}
}
// 示例用法
$host = "目标主机的IP地址或域名";
$startPort = 1;
$endPort = 100;
scanPort($host, $startPort, $endPort);
?>
```
请注意,由于端口扫描涉及到网络连接,因此可能需要一些权限和网络设置。此外,这只是一个简单的示例,对于大规模的端口扫描或复杂的网络环境可能需要更复杂和高级的方法和工具来完成。
用python写一个端口扫描脚本
### 回答1:
你好,我是 CSDN 开发的 C 知道,关于你的问题,我可以回答。以下是一个简单的 Python 端口扫描脚本示例:
```python
import socket
target_host = input("请输入要扫描的目标主机:")
target_ports = input("请输入要扫描的目标端口(多个端口用逗号分隔):")
# 将输入的端口号转换为列表
target_ports = target_ports.split(",")
# 创建 socket 对象
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置超时时间
client.settimeout(.5)
# 遍历端口列表,进行扫描
for port in target_ports:
try:
# 连接目标主机和端口
client.connect((target_host, int(port)))
print("端口 {} 开放".format(port))
except:
print("端口 {} 关闭".format(port))
finally:
# 关闭连接
client.close()
```
希望能够帮助到你。
### 回答2:
端口扫描是网络安全中的一项重要任务,可以用来探测目标主机上开放的网络端口,进而判断目标主机上的服务或应用程序。下面是一个使用Python编写的简单端口扫描脚本。
```python
import socket
# 定义要扫描的目标主机和端口范围
target_host = "localhost"
target_ports = [80, 443, 8080]
# 创建socket对象
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置超时时间(可选)
sock.settimeout(2)
# 遍历端口范围,进行扫描
for port in target_ports:
try:
# 尝试连接目标主机的指定端口
result = sock.connect_ex((target_host, port))
# 判断连接是否成功
if result == 0:
print("Port {} is open".format(port))
else:
print("Port {} is closed".format(port))
except socket.timeout:
print("Port {} timed out".format(port))
except socket.error:
print("Error connecting to port {}".format(port))
finally:
# 关闭socket连接
sock.close()
```
以上脚本使用了Python的`socket`模块,通过`socket.socket()`方法创建一个TCP socket对象,并设置超时时间。然后,通过遍历指定的端口范围,使用`sock.connect_ex()`方法来尝试连接目标主机的每个端口。连接成功则表示该端口为开放状态,否则表示该端口为关闭状态。异常处理部分用于处理超时或连接错误的情况。
该脚本可以通过修改`target_host`和`target_ports`的值来扫描不同的目标主机和端口范围。注意:在进行端口扫描时,请遵守法律和道德规范,确保已取得所有必要的授权。
### 回答3:
Python是一种功能强大的编程语言,可以用来编写端口扫描脚本。以下是一个简单的示例:
```python
import socket
# 定义要扫描的目标主机和端口范围
target_host = "127.0.0.1"
start_port = 1
end_port = 100
# 循环扫描指定范围内的端口
for port in range(start_port, end_port+1):
# 创建一个socket对象
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.settimeout(0.5) # 设置连接超时时间为0.5秒
try:
# 尝试连接目标主机的指定端口
result = client.connect_ex((target_host, port))
if result == 0:
print(f"端口 {port} 是开放的")
except Exception as e:
print(f"发生异常:{e}")
finally:
client.close() # 关闭socket连接
```
在上述代码中,我们首先导入了socket模块,然后定义了目标主机和要扫描的端口范围。接下来,我们通过一个循环迭代的方式,依次尝试连接每个端口。连接成功返回0,表示端口是开放的,然后我们打印出来。如果连接出现异常,则打印异常信息。最后,我们要记得关闭socket连接。
使用这个脚本,你可以指定要扫描的目标主机和端口范围,然后运行脚本,它将会依次扫描指定范围内的端口,并将开放的端口打印出来。请注意,扫描端口时可能需要一段时间,具体时间取决于目标主机和端口的数量。