如何解决重新编译用“新”语言编写的二进制程序
所以我有以下挑战: 我收到二进制文件。在记事本++中打开时,第一行说:
This program is developed with specific programming language. Opcodes: 0x3F byte - gotox byte,0x40 byte - gotoy byte,0x2400 - print ' ',0x2401 - print ','
我从来没有做过这样的事情,但我想知道如何破解这个问题。基本上二进制文件是一个函数,我需要重新编译它并提取输出。
我的想法是用 C 以二进制格式打开文件,然后读取每个字节。但我不确定如何确切地做到这一点......应该是什么程序。读取每个字节然后什么?
感谢您的帮助:)
编辑:多亏了 clbx,我取得了一些真正的进步,但最后还是卡住了! 这是我的简单 C 代码:
#include <stdio.h>
#include <stdlib.h>
void gotoxy(int x,int y)
{
printf("%c[%d;%df",0x1B,y,x);
}
int main(int argc,char const *argv[])
{
FILE *fp = fopen("elbitsystems.elbit","rb");
unsigned char byte,x,print_code;
while (fread(&byte,1,fp) != 0)
{
switch (byte)
{
case 0x3F: // gotox byte
fread(&x,fp);
break;
case 0x40: // gotoy byte
fread(&y,fp);
break;
case 0x24: // print
fread(&print_code,fp);
if (print_code == 1)
{
gotoxy(x,y);
printf(",");
}
break;
default:
break;
}
}
fclose(fp);
printf("\n");
return 0;
}
这是我得到的输出:
我真的可以看到答案(“Sysco ..?”但其中一些被搞砸了,我不知道是怎么回事。我在网上找到了 gotoxy() 函数,它似乎有效......但并不完全。 我尝试不使用它,而是创建了大小为 255,255 的二维数组,并在 while 循环后将其写入文本文件,结果与上图相同。 知道我能做什么吗?我感觉离终点很近了……不知道该怎么办哈哈。 谢谢!!
解决方法
每个操作码都是一条指令,给定的字节决定了程序应该做什么。
看起来你只有 4 个操作码,这很容易:
0x3F 字节 - gotox 字节,
0x40 字节 - gotoy 字节,
0x2400 - 打印 ' ',
0x2401 - 打印 ','
您在正确的轨道上,打开文件并逐字节读取。当你得到一个你知道的字节 (0x3F,0x40,0x2400,0x2401) 时,执行它的相关函数 (goto x,goto y,print ' ',print '.'
,我也试图解决这个挑战,你做得很好! 请注意,在文件中间有更多的操作码字符。 "2=%,4=,16=#,32=(,64=/,128=*" 将它们添加到您的代码中,您将成功完成这个挑战!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。