通过检查 C 中的幻数来检查有效的可执行文件或 shell 文件
Check if valid executable or shell file by checking magic number in C
你会认识的魔法数字显示在下面table。
文件开头的文件类型名称幻数(字节):
-Executable ASCII characters DEL, ‘E’, ‘L’ and ‘F’
-Shell script ASCII characters ‘#’ and ‘!’
标准文件扩展名优先,即使它们包含幻数。例如,如果一个文件的扩展名为 .o
,那么它被计为一个 object
文件,即使
它还具有 executable
文件的幻数。
到目前为止,我一直没有成功地尝试实现我的代码,它似乎没有检查数字并添加到 exe 文件的总数中。逻辑不正确还是有更简单的检查方法?
感谢任何帮助
int main (int argc, char** argv) {
//
const unsigned char magic1[4] = {0x7f, 0x45, 0x4c, 0x46}; //DEL, E, L, F
char *endSlash = strrchr (argv[count], '/');
endSlash = endSlash ? endSlash + 1: argv[count];
char *endDot = strrchr (endSlash, '.');
FILE *file;
for (count = 1; count < argc; count++) {
file = fopen(argv[count], "r");
if (strcmp(endSlash, "Makefile") == 0 || strcmp(endSlash, "makefile") == 0) {
Mfile++;
}
else if (endDot == NULL) {
O++;
}
else if (endDot[1] == 'c' && endDot[2] == 0) {
Ccount++;
}
else if (endDot[1] == 'h' && endDot[2] == 0) {
Hcount++;
}
else if (endDot[1] == 'o' && endDot[2] == 0) {
Ocount++;
}
else if (memcmp(file, magic1, sizeof(magic1)) == 0) { //is this actually checking and comparing bytes of magic1?
Execount++;
}
else {
O++;
}
}
printf("C source: %d\n", Ccount);
printf("C header: %d\n", Hcount);
printf("Object: %d\n", Ocount);
printf("Make: %d\n", Mfile);
printf("Executable: %d\n", Execount);
printf("Shell: %d\n", Shcount);
printf("Other: %d\n", O);
从文件中读取 4 个字节的数据,然后执行 memcmp .. 像这样
char buf[4] ;
fread(buf,sizeof(char),4,file) ;
memcmp(buf,magic1,sizeof(magic1));
你会认识的魔法数字显示在下面table。
文件开头的文件类型名称幻数(字节):
-Executable ASCII characters DEL, ‘E’, ‘L’ and ‘F’
-Shell script ASCII characters ‘#’ and ‘!’
标准文件扩展名优先,即使它们包含幻数。例如,如果一个文件的扩展名为 .o
,那么它被计为一个 object
文件,即使
它还具有 executable
文件的幻数。
到目前为止,我一直没有成功地尝试实现我的代码,它似乎没有检查数字并添加到 exe 文件的总数中。逻辑不正确还是有更简单的检查方法?
感谢任何帮助
int main (int argc, char** argv) {
//
const unsigned char magic1[4] = {0x7f, 0x45, 0x4c, 0x46}; //DEL, E, L, F
char *endSlash = strrchr (argv[count], '/');
endSlash = endSlash ? endSlash + 1: argv[count];
char *endDot = strrchr (endSlash, '.');
FILE *file;
for (count = 1; count < argc; count++) {
file = fopen(argv[count], "r");
if (strcmp(endSlash, "Makefile") == 0 || strcmp(endSlash, "makefile") == 0) {
Mfile++;
}
else if (endDot == NULL) {
O++;
}
else if (endDot[1] == 'c' && endDot[2] == 0) {
Ccount++;
}
else if (endDot[1] == 'h' && endDot[2] == 0) {
Hcount++;
}
else if (endDot[1] == 'o' && endDot[2] == 0) {
Ocount++;
}
else if (memcmp(file, magic1, sizeof(magic1)) == 0) { //is this actually checking and comparing bytes of magic1?
Execount++;
}
else {
O++;
}
}
printf("C source: %d\n", Ccount);
printf("C header: %d\n", Hcount);
printf("Object: %d\n", Ocount);
printf("Make: %d\n", Mfile);
printf("Executable: %d\n", Execount);
printf("Shell: %d\n", Shcount);
printf("Other: %d\n", O);
从文件中读取 4 个字节的数据,然后执行 memcmp .. 像这样
char buf[4] ;
fread(buf,sizeof(char),4,file) ;
memcmp(buf,magic1,sizeof(magic1));