C++ 脚本/工具,用于转换由“C”编码的C源代码;xxd-i“;到C源代码?
是否有Linux/Unix工具可用于将C文件的十六进制转储数组(即C++ 脚本/工具,用于转换由“C”编码的C源代码;xxd-i“;到C源代码?,c++,c,linux,unix,xxd,C++,C,Linux,Unix,Xxd,是否有Linux/Unix工具可用于将C文件的十六进制转储数组(即xxd-i的输出)转换为相应的源代码?该工具是免费的,在Linux上工作,在SourceForge上可用。源文件xxd-i xyz.C的输出如下所示: unsigned char xyz_c[] = { 0x23, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x20, 0x3c, 0x73, 0x74, 0x64, 0x69, 0x6f, 0x2e, 0x68, 0x3e, 0x0
xxd-i
的输出)转换为相应的源代码?该工具是免费的,在Linux上工作,在SourceForge上可用。源文件xxd-i xyz.C
的输出如下所示:
unsigned char xyz_c[] = {
0x23, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x20, 0x3c, 0x73, 0x74,
0x64, 0x69, 0x6f, 0x2e, 0x68, 0x3e, 0x0a, 0x23, 0x69, 0x6e, 0x63, 0x6c,
0x75, 0x64, 0x65, 0x20, 0x3c, 0x73, 0x74, 0x64, 0x6c, 0x69, 0x62, 0x2e,
0x68, 0x3e, 0x0a, 0x23, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x20,
0x3c, 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x2e, 0x68, 0x3e, 0x0a, 0x0a,
…
0x65, 0x5f, 0x6c, 0x69, 0x73, 0x74, 0x28, 0x73, 0x74, 0x61, 0x72, 0x74,
0x29, 0x3b, 0x0a, 0x20, 0x20, 0x20, 0x20, 0x7d, 0x0a, 0x0a, 0x20, 0x20,
0x20, 0x20, 0x72, 0x65, 0x74, 0x75, 0x72, 0x6e, 0x20, 0x30, 0x3b, 0x0a,
0x7d, 0x0a
};
unsigned int xyz_c_len = 4442;
假设它存储在文件xyz.xxd
中
在许多方面,重新生成原始代码的最简单方法是:
#include <stdio.h>
#include "xyz.xxd"
int main(void)
{
for (unsigned int i = 0; i < xyz_c_len; i++)
putchar(xyz_c[i]);
return 0;
}
它使用“自动拆分”选项(
-a
)和“自动读取但不打印”选项(-n
),然后处理输入中看起来像十六进制字符的任何字,例如0x0a(可选后跟逗号,因为xxd-i
在最后一个字节值之后有点不必要地省略逗号)并将其转换为相应的字节。它是Perl,TMTOWTDI——有不止一种方法可以做到这一点。你是说反汇编程序吗?或者是逆向工程?我想你需要一个反编译器。我想这个问题会让你觉得,如果你的意思是回到二进制,而不是src代码。就像乔纳森回答的那样。在这种情况下,xxd似乎缺少一种无法反转的格式。
#!/usr/bin/env perl -na
use strict;
use warnings;
# xxd -i drops the final comma - aargh (why?)!
foreach my $word (@F)
{
next unless $word =~ m/^0[Xx][[:xdigit:]]{2},?$/;
$word =~ s/,//;
printf "%c", hex($word);
}