星星博客 »  > 

攻防世界 REVERSE 新手区/open-source

攻防世界 REVERSE 新手区/open-source

在这里插入图片描述

下载附件得到一段c语言代码,一共有4个if语句,条件有一个满足就会退出程序

在这里插入图片描述

先看到flag的出现条件,看来hash就是flag

在这里插入图片描述

可以看到hash与三个值有关,其他都是常数,接下来就是一点点来分析代码了

这段对结果的值没有影响,可以直接略过

int main(int argc, char *argv[]) {
    if (argc != 4) {
    	printf("what?\n");
    	exit(1);
    }

这段影响的是first的取值,如果first不等于0xcafe就退出程序,那么first 就等于 0xcafe
(stoi函数是将字符串转为十进制数字)

 unsigned int first = atoi(argv[1]);
    if (first != 0xcafe) {
    	printf("you are wrong, sorry.\n");
    	exit(2);
    }

这段影响的是second的取值,看判断条件 if (second % 5 == 3 || second % 17 != 8) ,那么可以推出second求余17就必须等于8且second求余5不能等于3,刚好second等于25可以满足这个条件

 unsigned int second = atoi(argv[2]);
    if (second % 5 == 3 || second % 17 != 8) {
    	printf("ha, you won't get it!\n");
    	exit(3);
    }

这段很明显,argv[3]就等于 “h4cky0u”,那么strlen(argv[3])就等于7

 if (strcmp("h4cky0u", argv[3])) {
    	printf("so close, dude!\n");
    	exit(4);
    }

这三个值都知道了,前面的东西都注释掉就行了

在这里插入图片描述

运行得到flag

在这里插入图片描述

相关文章