C++ Builder下端口映射服务器的开发与研究(更新版)

(同一个世界,同一个梦想,交流学习C++Builder XE10,传承c++builder的魅力!欢迎各地朋友加入我的QQ群484979943,进群密码“BCB”,同时也请将该群号广为宣传,希望能够广集各方高手,共同进步。)

一、业务需求     

端口映射即网络代理,其功能与路由器等网络设备基本类似,常用的软件代理也很多,但是如何自己动手开发一个端口映射代理呢?比如某银行的外联业务场景,详情如下:

ServerA银行方系统<------------------>ServerC合作方系统

根据总行稽核部要求,银行系统和合作方系统不能直接对接,防止网络入侵或数据泄密,为此需要开发一个外联网关,只做数据透传,不做加工处理,数据更是不能落地,详情如下:

ServerA银行方系统<--------->ServerB银行方外联网关<--------->ServerC合作方系统

二、设计目标

开发一个外联网关通讯系统ServerB,架设在ServerA和ServerC之间,能够将来源于ServerA_ip:ServerA_Port端口的通讯请求转发给ServerC_ip:ServerC_Port,不留下任何痕迹,支持TCP映射、FTP映射、TELENT、UDP、HTTP映射等。

三、主要功能

1)TCP网关服务功能能够将来源端口的SOCKET报文转发为另一端口的SOCKET报文。除了金融交易报文外,常用的TOAD、远程桌面、VNC远程控制、中国银行CSP配置工具等都可以通过该服务转发。TELNET的默认端口是23,SFTP和SSH功能默认端口都是22,经测试都可以使用本系统的TCP网关服务透传。

2)UDP网关服务能够进行UDP端口透传。

3)FTP网关服务功能能够将来源端口的FTP请求映射为另一端口的FTP请求。该功能不需要知道用户名和密码,数据不落地透明转发。测试过的软件有Xftp和windows下的命令FTP和文件夹下的ftp。该功能不支持SFTP,SFTP可以通过TCP网关服务实现。

4)HTTP网关服务能够进行代理方式的http和https网站透传,测试过的网址有www.boc.cn,www.sina.com.cn,www.qq.com等。启动HTTP网关服务,在浏览器上设定本代理的地址和端口即可以访问目标WEB网站系统。

5)TELNET网关服务功能能够将来源端口的TELNET请求映射为另一端口的TELNET请求。该功能不支持SSH协议,支持TELNET协议,客户端连接成功后请先敲击一个回车,然后就可以进行正常操作了。测试过的软件有Xshell。SSH协议可以通过TCP网关服务实现。

6)POP3邮件网关服务:暂未开发,可以根据需要定制开发。


四、功能实现

本文基于C++Builder 10.2.2tokyo开发工具,调用Indy控件IdMappedPortTCP、IdMappedFTP、IdMappedTelnet、IdMappedPortUDP、IdHTTPProxyServer控件实现上述需求。

1、IdMappedPortTCP实现

    IdMappedPortTCP1->DefaultPort=tMapPort1[i].ToInt();//ServerB监听端口
    IdMappedPortTCP1->MappedHost=tMapIp2[i];//映射地址,即ServerC主机地址
    IdMappedPortTCP1->MappedPort=tMapPort2[i].ToInt();//映射端口,即ServerC监听端口

    try
        {
        IdMappedPortTCP1->Active=true;
        }
    catch(...)
        {
        ShowMessage("启动失败!");
        }

举例:通过tcp映射服务实现web浏览器通过代理网关访问新浪网

1)本程序映射设置

本地监听8686端口(可以变),映射为新浪网的地址www.sina.com.cn和默认端口80(不能变),设置好用启动服务。

2)打开IE浏览器,在Internet选项-》连接-》局域网设置-》代理服务器下设置好你运行代理服务器的主机地址(本次测试用192.168.1.88)和端口8686。

                       (要勾选上代理服务器)

3)关闭重新启动IE浏览器,在地址栏输入www.sina.com.cn即可通过你开发的代理网关访问新浪网了。

2、IdMappedFTP实现

    IdMappedFTP1->DefaultPort=fMapPort1[i].ToInt();//ServerB监听端口
    IdMappedFTP1->MappedHost=fMapIp2[i];//映射地址,即ServerC主机地址
    IdMappedFTP1->MappedPort=fMapPort2[i].ToInt();//映射端口,即ServerC监听端口

    try
        {
        IdMappedFTP1->Active=true;
        }
    catch(...)
        {
       ShowMessage("启动失败!");
        }

上述代码能够实现常用FTP服务器映射访问,Xftp测试正常,但是中文文件名的文件传输失败,报错代码501,目前尚未解决,可能是传输编码问题。不支持SFTP。

3、IdMappedTelnet实现

    IdMappedTelnet1->DefaultPort=eMapPort1[i].ToInt();//ServerB监听端口
    IdMappedTelnet1->MappedHost=eMapIp2[i];//映射地址,即ServerC主机地址
    IdMappedTelnet1->MappedPort=eMapPort2[i].ToInt();//映射端口,即ServerC监听端口


    try
        {
        IdMappedTelnet1->Active=true;
        }
    catch(...)
        {
       ShowMessage("启动失败!");
        }

上述代码能够实现telnet服务的映射,telnet工具经过代理连接成功后,需要后在客户端工具先敲一下回车,然后就可以正常进入主机操作了。不支持STELNET。

4、IdMappedPortUDP实现

                IdMappedPortUDP1->DefaultPort=uMapPort1[i].ToInt();
                IdMappedPortUDP1->MappedHost=uMapIp2[i];
                IdMappedPortUDP1->MappedPort=uMapPort2[i].ToInt();
                try
                    {
                    IdMappedPortUDP1->Active=true;
                    }
                catch(...)
          {
         ShowMessage("启动失败!");
          }

5、IdHTTPProxyServer实现

                                IdHTTPProxyServer1->DefaultPort=hMapPort1[i].ToInt();
IdHTTPProxyServer1->TerminateWaitTime=hWaitTime[i].ToInt();
IdHTTPProxyServer1->MaxConnections=hMaxCount[i].ToInt();
try
{
IdHTTPProxyServer1->Active=true;

     }

catch(...)
            {
           ShowMessage("启动失败!");
            }

本功能支持http和https代理,浏览器下的测试需要先给浏览器配置代理服务器,详细说明可参考上述举例:“四、1、1)”。

五、程序界面

本次开发的是一个各种协议能支持并行20个端口服务的项目设计,上述代码只是简要说明了单个服务的配置与启动。Indy为了防止通讯中转时程序假死,可以放置一个IdAntiFreeze控件在主界面上。


运行界面:


四、开发小结

Indy组件是一套功能强大的通讯组件,但是遗憾的是,官方文档写的太不详细了,国内能够查询到的资源太少了。这也许是因为java当道,用C++Builder的IT农民工太少了的原因吧。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
端口映射器(Portmap) 1.0 使用说明 1、主要功能: 该工具可以将A机器上的某一个端口(可设置)映射到B机器的某个端口(可设置),也就是将这两个端口的数据传输对应起来,其工作流程是这样的: 在机器A的端口接收到连接请求以后,Portmap马上试图连接B机器的端口,连接成功后,Portmap就在这两个端口之间就建立起一条数据通路,进行数 据转发,任何一方关闭连接,数据通路就断开。 2、设置 所有的设置都在Portmap.ini中,每一个Entry代表建立一个数据转发器,一共支持1024个。 3、安装方式 系统可以以NT系统服务方式运行,也可以直接运行(9x下); 1、下载 直接将文件解压缩一个独立的目录下面(注意不能有空格和中文名), 2、安装服务 Portmapsvc -install 安装后,服务将把自己设为自动启动; 3、卸载服务 Portmapsvc -uninstall 4、启动和停止服务 请到NT服务控制器执行! 5、9x下直接运行 请在命令行下键入: Portmapsvc -run 即可. 4、Portmap.ini说明 Enable=1 ;; 1代表启用这个数据转发器, 0则相反 InnerIP=192.168.1.198 ;; B机器的IP地址 InnerPort=21 ;; B机器的端口 ServerIP=x.x.x.x ;; A机器的IP地址 ServerPort=5021 ;; A机器的端口 5、注册方式 该软件可以免费使用,但是如果你不希望每次启动时都打开注册对话框,你可以考虑注册,注册请联系: MSN: skyvense@msn.com ICQ: 104180227 OICQ: 2091910 Email: skyvense@online.sh.cn, skyvense@vip.sina.com 张小峰(2002/10/02 01:59)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值