下面是我的C++代码,我试图备份一个文件,包括安全信息。我使用了备份读取,但每当调用代码时,exe就会崩溃。
char buff[225280];
DWORD numberOfBytesToRead = 225280;
DWORD dwBytesRead=0, dwBytesWritten, dwBytesRead2=0;
BOOL bProcessSecurity = TRUE;
LPWSTR sourceBackupFile = L"E:\myFolder\backup.txt";
HANDLE source = CreateFile(sourceBackupFile, GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
// Check for errors
if (source == INVALID_HANDLE_VALUE) {
cout<<"The Handle is Invalid:"<<GetLastError()<<endl;
}
else
{
cout<< "n The source file is in E:\myFolder\backup.txt" <<endl ;
}
LPDWORD numberofbytedsreadinreadFile = 0;
cout << "Point Of Crash" << endl;
if (!BackupRead(
source,
&buff,
numberOfBytesToRead,
numberofbytedsreadinreadFile,
FALSE,
TRUE,
NULL
))
{
cout << "Backup Read Failed with the error::" << GetLastError() << endl ;
}
它在崩溃之前打印这个
The source file is in E:\myFolder\backup.txt
"Point of Crash"
您将NULL
作为最后一个参数传递给BackupRead
,根据文档,这显然是无效的。
lpContext[out]指向一个变量的指针,该变量接收指向BackupRead用于维护上下文的内部数据结构备份操作期间的信息。您必须设置变量在第一次调用BackupRead之前由lpContext指向NULL用于指定的文件或目录。该函数为分配内存数据结构,然后将变量设置为指向结构您不能更改lpContext或它的变量在对BackupRead的调用之间指向。释放使用的内存在数据结构中,调用BackupRead,并将bAbort参数设置为备份操作完成时为TRUE。
您应该传递一个指向它的指针,该指针指向null,而不是null值。(LPVOID
表示void*
,LPVOID**
表示void**
)
与numberofbytedsreadinreadFile
相同:应该将参数传递给现有变量,而不是null指针,它是out参数。
void* backupContext = NULL;
int numberOfBytesRead = 0;
cout << "Point Of Crash" << endl;
if (!BackupRead(
source,
&buff,
numberOfBytesToRead,
&numberOfBytesRead,
FALSE,
TRUE,
&backupContext
))
如果得到一个无效的句柄,而不是继续,那么也应该从该方法返回。