攻防世界 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