ImCehnyx

利用 fsockopen() 函数开放端口扫描器

1、前言

本文利用 fsockopen() 函数,编写一个功能简单的端口扫描器。

2、关键技术

本实例的端口号是固定的,通过对数组的遍历,利用 fsockopen() 函数连接,如果连接成功,则该端口处于开放状态,否则该端口处于关闭状态。

核心代码如下:

foreach ($port as $key => $value) {
    echo \'<tr>\';
    echo \'<td>\' . $key . \'</td>\';
    echo \'<td>\' . $value . \'</td>\';
    echo \'<td>\' . $msg[$key] . \'</td>\';
    //$errno 和 $errstr 在这里基本用不上,只是为了设置 timeout,防止请求超时
    $fp = @fsockopen($ip, $value, $errno, $errstr, 1);//如果主机(hostname)不可访问,将会抛出一个警告级别(E_WARNING)的错误提示。所有需要加@
    $result = $fp ? \'<span style="color:red">开启</span>\' : \'<span style="color:red">关闭</span>\';
    echo \'<td>\' . $result . \'</td>\';
    echo \'</tr>\';
}

 

3、代码如下

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>端口扫描</title>
    <style type="text/css">
        td{
            padding:10px;
            border-bottom:1px solid #eee;
        }
    </style>
</head>
<body>
    <form method="post" action=\'#\'>
        网址/ip:<input type="text" name="ip" value="<?php echo  $_POST[\'ip\'] ?? \'127.0.0.1\'?>">
        <button>扫描</button>
    </form>
    <table>
        <thead>
            <tr>
                <td>id</td>
                <td>端口号</td>
                <td>服务</td>
                <td>开启状态</td>
            </tr>
        </thead>
        <tbody>
            <?php  
                $ip = $_POST[\'ip\'] ?? \'127.0.0.1\';
                if(ip2long($ip)){
                    $aIp = explode(\'.\', $ip);//ip4地址使用.分隔符
                    //这里没有对 0.0.0.0 这种本机地址进行判断,只是粗略的判断ip是否合法 
                    foreach ($aIp as $key => $value) {
                        if($value < 0 || $value > 255){
                            die(\'地址不合法\');
                        }
                    }
                }
                
                $port = array(
                    21, 
                    23, 
                    25,
                    79,
                    80, 
                    110, 
                    135, 
                    137, 
                    138, 
                    139, 
                    143, 
                    443, 
                    445, 
                    1433, 
                    3306, 
                    3389
                );
                $msg = array(
                    \'Ftp\',
                    \'Telnet\',
                    \'Smtp\',
                    \'Finger\',
                    \'Http\',
                    \'Pop3\',
                    \'Location Service\',
                    \'Netbios-NS\',
                    \'Netbios-DGM\',
                    \'Netbios-SSN\',
                    \'IMAP\',
                    \'Https\',
                    \'Microsoft-DS\',
                    \'MSSQL\',
                    \'MYSQL\',
                    \'Terminal Services\'
                );
                //无论使用prot还是msg循环都是可以的,因为$key是对应的,都是索引数组
                foreach ($port as $key => $value) {
                    echo \'<tr>\';
                    echo \'<td>\' . $key . \'</td>\';
                    echo \'<td>\' . $value . \'</td>\';
                    echo \'<td>\' . $msg[$key] . \'</td>\';
                    //$errno 和 $errstr 在这里基本用不上,只是为了设置 timeout,防止请求超时
                    $fp = @fsockopen($ip, $value, $errno, $errstr, 1);//如果主机(hostname)不可访问,将会抛出一个警告级别(E_WARNING)的错误提示。所有需要加@
                    $result = $fp ? \'<span style="color:red">开启</span>\' : \'<span style="color:red">关闭</span>\';
                    echo \'<td>\' . $result . \'</td>\';
                    echo \'</tr>\';
                }

            ?>
        </tbody>
    </table>
</body>
</html>

 

</html> 
因为偷懒,把页面和结果都写在一起了,布局就将就把。

 

4、主要函数介绍

4.1、fsockopen

根据一个主机名来创建一个连接,成功返回一个资源对象,失败返回false;主机不可用是抛出一个警告

详情参考:http://php.net/manual/en/function.fsockopen.php

分类:

技术点:

相关文章: