日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

BUUOJ reverse 不一样的flag

發布時間:2023/12/10 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BUUOJ reverse 不一样的flag 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

不一樣的flag

是不是做習慣了常規的逆向題目?試試這道題,看你在能不能在程序中找到真正的flag!注意:flag并非是flag{XXX}形式,就是一個’字符串‘,考驗眼力的時候到了! 注意:得到的 flag 請包上 flag{} 提交

?

ida看偽C代碼:

int __cdecl main(int argc, const char **argv, const char **envp) {char v3; // [esp+17h] [ebp-35h]int v4; // [esp+30h] [ebp-1Ch]int v5; // [esp+34h] [ebp-18h]signed int v6; // [esp+38h] [ebp-14h]int i; // [esp+3Ch] [ebp-10h]int v8; // [esp+40h] [ebp-Ch] __main();v4 = 0;v5 = 0;qmemcpy(&v3, _data_start__, 0x19u);while ( 1 ){puts("you can choose one action to execute");puts("1 up");puts("2 down");puts("3 left");printf("4 right\n:");scanf("%d", &v6);if ( v6 == 2 ){++v4;}else if ( v6 > 2 ){if ( v6 == 3 ){--v5;}else{if ( v6 != 4 ) LABEL_13:exit(1);++v5;}}else{if ( v6 != 1 )goto LABEL_13;--v4;}for ( i = 0; i <= 1; ++i ){if ( *(&v4 + i) < 0 || *(&v4 + i) > 4 )exit(1);}if ( *((_BYTE *)&v8 + 5 * v4 + v5 - 41) == 49 )exit(1);if ( *((_BYTE *)&v8 + 5 * v4 + v5 - 41) == 35 ){puts("\nok, the order you enter is the flag!");exit(0);}} }

可以看到每次都將用戶的輸入存到v6里面,然后根據v6的值來調整v4和v5的值,輸入1就讓v4--?? 2就讓v4++? 3就讓v5--?? 4就讓v5++

下面這一段代碼說明v4 和v5取值都必須在0~4之間:

for ( i = 0; i <= 1; ++i ){if ( *(&v4 + i) < 0 || *(&v4 + i) > 4 )exit(1);}

關鍵在于這一段代碼:

if ( *((_BYTE *)&v8 + 5 * v4 + v5 - 41) == 49 )exit(1);if ( *((_BYTE *)&v8 + 5 * v4 + v5 - 41) == 35 ){

我們仔細看主函數的代碼,發現v8是一直沒有動過的,再仔細算一下? &v8 + 5 * v4 + v5 - 41 這個偏移量是 &v8-41 到&v8-17之間,也就是完全落在v3的25個值里面!

他的邏輯是 如果算出來&v8 + 5 * v4 + v5 - 41 這個偏移量對應的值如果是1就退出,否則繼續,直到找到“#”這個值

所以這個題本質上是個走迷宮.........

純手走的 答案是:222441144222

轉載于:https://www.cnblogs.com/dyhaohaoxuexi/p/11421648.html

總結

以上是生活随笔為你收集整理的BUUOJ reverse 不一样的flag的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。