在C ++中使用ReadFIle()函数时无法从文件读取

时间:2014-11-07 05:38:11

标签: c++ visual-c++ file-io msdn file-management

我在使用C ++的ReadFile()函数从文件读取数据时遇到一些问题(可能是微软特定的)。

这是我的代码

在文件上写入

void ClientA::SharePublicKey()
{
    printf("Sharing Public Key\n");
    HANDLE hFile = NULL;

    hFile = CreateFile(TEXT("D:\\My_Proj\\shared\\PublicKeyB.txt"),                // name of the write
                       GENERIC_WRITE,          // open for writing
                       FILE_SHARE_WRITE,                      // do not share
                       NULL,                   // default security
                       CREATE_NEW,             // create new file only
                       FILE_ATTRIBUTE_NORMAL,  // normal file
                       NULL);                  // no attr. template

    if (hFile == INVALID_HANDLE_VALUE) 
    { 
        //DisplayError(TEXT("CreateFile"));
        //_tprintf(TEXT("Terminal failure: Unable to open file \"%s\" for write.\n"), argv[1]);
        return;
    }

   // _tprintf(TEXT("Writing %d bytes to %s.\n"), dwBytesToWrite, argv[1]);

    bool bErrorFlag = WriteFile( 
                    hFile,           // open file handle
                    pbPublicKey,      // start of data to write
                    dwPublicKeyLen,  // number of bytes to write
                    &lpNumberOfBytesWritten, // number of bytes that were written
                    NULL);            // no overlapped structure

    if (FALSE == bErrorFlag)
    {
       // DisplayError(TEXT("WriteFile"));
        printf("Terminal failure: Unable to write to file.\n");
        return;
    }
    else
    {
        if (lpNumberOfBytesWritten != dwPublicKeyLen)
        {
            // This is an error because a synchronous write that results in
            // success (WriteFile returns TRUE) should write all data as
            // requested. This would not necessarily be the case for
            // asynchronous writes.
            printf("Error: dwBytesWritten != dwBytesToWrite\n");
        }
        else
        {
          //  _tprintf(TEXT("Wrote %d bytes to %s successfully.\n"), dwBytesWritten, argv[1]);
        }
    }

    CloseHandle(hFile);
}

读取该文件

void ClientA::ReadPublicKeyOfOtherPeer()
{
    HANDLE hFile = NULL; 
    DWORD  dwBytesRead = 0;
    BYTE*   ReadBuffer = NULL;
    OVERLAPPED ol = {0};


    hFile = CreateFile(TEXT("D:\\My_Proj\\shared\\PublicKeyB.txt"),               // file to open
                        GENERIC_READ,          // open for reading
                       FILE_SHARE_READ,       // share for reading
                       NULL,                  // default security
                       OPEN_EXISTING,         // existing file only
                       FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED, // normal file
                       NULL                 // no attr. template
                       );

    if (hFile == INVALID_HANDLE_VALUE) 
    { 
        _tprintf(TEXT("CreateFile\n"));
        _tprintf(TEXT("Terminal failure: unable to open file \"%s\" for read.\n"));
        printf("Error %x\n", GetLastError());
        return; 
    }



    if( FALSE == ReadFile(hFile, ReadBuffer, dwPublicKeyLen, &lpNumberOfBytesWritten, &ol) )
    {
       // DisplayError(TEXT("ReadFile"));
        printf("Terminal failure: Unable to read from file.\n GetLastError=%08x\n", GetLastError());
        CloseHandle(hFile);
        return;
    }


    if (dwBytesRead > 0 && dwBytesRead <= dwPublicKeyLen-1)
    {
        ReadBuffer[dwBytesRead]='\0'; // NULL character

        //_tprintf(TEXT("Data read from %s (%d bytes): \n"), argv[1], dwBytesRead);
        printf("%s\n", ReadBuffer);
    }
    else if (dwBytesRead == 0)
    {
        //_tprintf(TEXT("No data read from file %s\n"), argv[1]);
    }
    else
    {
       // printf("\n ** Unexpected value for dwBytesRead ** \n");
    }

    retrievedPublicByteArray = ReadBuffer;




    CloseHandle(hFile);
}

通过 SharePublicKey 方法我将数据保存在文件中。我已经检查过它是否成功保存了文件中的数据,并且文件上的数据似乎是有效的。

通过 ReadPublicKeyOfOtherPeer 方法,我正在读取之前保存的文件。但阅读不成功在外面我找到了以下一行 -

终端失败:无法从文件中读取。 GetLastError函数= 000003e6

1 个答案:

答案 0 :(得分:0)

您正在将未初始化的指针ReadBuffer传递给ReadFile。您需要一个足够大的缓冲区来接收结果。