我正在做一个任务,我们应该对一个用糟糕的加密算法加密的 PDF 进行加密分析。
教授提供的代码使用fd=open(filename, O_CREAT|O_WRONLY, S_IRUSR|S_IWUSR)
.
在我尝试解密的代码中,我使用fd_in=open(file, O_RDONLY)
.
问题是当我尝试从文件中读取时,我收到“错误的文件描述符”错误。我使用 stat 尝试获取有关文件描述符对已打开文件的“想法”的更多信息,它表明该文件的长度为 0,而实际上它只有几百 KB。
我正在使用的调试代码是:
if (0 > (len = read(fd_in, (char*)&read_buff, BITE))) { // BITE is defined as 8
printf("Error occured grabbing first bite of %s.\n", file);
printf("%s.\n", strerror(errno));
struct stat fileStat;
int stat = fstat(fd_in, &fileStat);
printf("fstat returned: %d.\n", stat); // Consistently printing 0
printf("Information for %s\n",file);
printf("---------------------------\n");
printf("File Size: \t\t%d bytes\n",fileStat.st_size);
printf("Number of Links: \t%d\n",fileStat.st_nlink);
printf("File inode: \t\t%d\n",fileStat.st_ino);
printf("File Permissions: \t");
printf( (S_ISDIR(fileStat.st_mode)) ? "d" : "-");
printf( (fileStat.st_mode & S_IRUSR) ? "r" : "-");
printf( (fileStat.st_mode & S_IWUSR) ? "w" : "-");
printf( (fileStat.st_mode & S_IXUSR) ? "x" : "-");
printf( (fileStat.st_mode & S_IRGRP) ? "r" : "-");
printf( (fileStat.st_mode & S_IWGRP) ? "w" : "-");
printf( (fileStat.st_mode & S_IXGRP) ? "x" : "-");
printf( (fileStat.st_mode & S_IROTH) ? "r" : "-");
printf( (fileStat.st_mode & S_IWOTH) ? "w" : "-");
printf( (fileStat.st_mode & S_IXOTH) ? "x" : "-");
printf("\n\n");
return 1;
}
我得到的结果是:
Error occured grabbing first bite of enc.pdf.
Bad file descriptor.
Information for enc.pdf
---------------------------
File Size: 0 bytes
Number of Links: 1
File inode: 16441996
File Permissions: -rw-------
ls 将文件报告为
-rw------- 1 matt matt 157887 Oct 29 03:01 enc.pdf
与打开文件相关的代码:
int fd_in=open(file, O_RDONLY);
if(fd_in<0) {
printf("Failed to open the input file %s.\n", file);
return 1;
} else {
printf("File open, descriptor is: %d.\n", fd_in);
}
这一直打印出字段描述符的值 3。
有一些关于 read_buff 的问题。加密/解密过程涉及对读取的值进行异或。因此,缓冲区被声明为 aunsigned long long
并且为了读入它,我获取地址并将其转换为 (char*)。这种策略直接来自于教授创建加密文件的代码。
我什至添加了一个带有 printf 的 else 来验证文件描述符是否有效。目前它似乎始终如一3
,这绝对不是-1