CreateFile调用总是失败,怎么回事?

celltree001 2008-12-14 11:22:18
CreateFile这个函数打开文件的时候总是失败,大家帮忙分析一个,这是什么原因呢?
#include<time.h>
#include<stdio.h>
#include<stdlib.h>
#include<windows.h>

HANDLE hFile;
HANDLE hFileMapping=NULL;
void *pFileBase=NULL;

int main(int argc,char **argv)
{
if(argc!=2)
{
printf("Usage:\n\t %s PE File\n",argv[0]);
exit(1);
}

/*********************** Map the file to memory *************************/
hFile=CreateFile(argv[1],GENERIC_READ,FILE_SHARE_READ|FILE_SHARE_WRITE,NULL,
FILE_ATTRIBUTE_ARCHIVE,OPEN_EXISTING,NULL);
if(hFile==INVALID_HANDLE_VALUE)
{
/*printf("Open File Error.\n");*/
printf("Open File Error\n");
exit(2);
}

hFileMapping=CreateFileMapping(hFile,NULL,PAGE_READONLY,0,0,NULL);
if(!hFileMapping)
{
CloseHandle(hFile);
perror("Create File Mapping Error\n");
exit(3);
}
pFileBase=MapViewOfFile(hFileMapping,FILE_MAP_READ,0,0,0);
if(!pFileBase)
{
CloseHandle(hFileMapping);
CloseHandle(hFile);
perror("Map View of File Error.\n");
exit(4);
}
/*********************** Map end *****************************************/


return EXIT_SUCCESS;
}
...全文
621 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
金金2019 2008-12-14
  • 打赏
  • 举报
回复
添加 debug 参数
c:\1.txt

你的 API 参数写错了
晕倒。 好好看看API 怎么用
金金2019 2008-12-14
  • 打赏
  • 举报
回复
// fileDemo.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

#include<time.h>
#include<stdio.h>
#include<stdlib.h>
#include<windows.h>
#include "tchar.h"
HANDLE hFile;
HANDLE hFileMapping=NULL;
void *pFileBase=NULL;

int main(int argc,char *argv[])
{
if(argc!=2)
{
printf("Usage:\n\t %s PE File\n",argv[0]);
exit(1);
}

/*********************** Map the file to memory *************************/
hFile=CreateFile(argv[1],GENERIC_READ, 0, (LPSECURITY_ATTRIBUTES)NULL,
OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL ,(HANDLE)NULL);
if(hFile==INVALID_HANDLE_VALUE)
{
/*printf("Open File Error.\n");*/
printf("Open File Error\n");
exit(2);
}

hFileMapping=CreateFileMapping(hFile,NULL,PAGE_READONLY,0,0,NULL);
if(!hFileMapping)
{
CloseHandle(hFile);
perror("Create File Mapping Error\n");
exit(3);
}
pFileBase=MapViewOfFile(hFileMapping,FILE_MAP_READ,0,0,0);
if(!pFileBase)
{
CloseHandle(hFileMapping);
CloseHandle(hFile);
perror("Map View of File Error.\n");
exit(4);
}
/*********************** Map end *****************************************/


return EXIT_SUCCESS;
}

ndchenxiaofeng 2008-12-14
  • 打赏
  • 举报
回复
同情...UP
celltree001 2008-12-14
  • 打赏
  • 举报
回复
存在啊。我在命令符下运行这个命令,肯定会给它一个存在的文件的。。。
CodeProject-Jerry 2008-12-14
  • 打赏
  • 举报
回复
貌似是文件不存在。。。 你打开的时候用了OPEN_EXISTING
CodeProject-Jerry 2008-12-14
  • 打赏
  • 举报
回复
参数 argv[1] 是什么? 此文件是否存在??

GetLastError() 是多少?
wap21 2008-12-14
  • 打赏
  • 举报
回复
不懂,up
celltree001 2008-12-14
  • 打赏
  • 举报
回复
哦。。。多谢各位大虾的帮忙
使用 易语言 进行硬盘操作,获取硬盘大小。 已经测试的操作系统:{ WINDOWS XP SP3 WINDOWS 7 X64 SP1 WINDOWS 2008 X64 } 其中包含的知识点: 【1】:CreateFile()打开物理驱动器操作,固定格式:“ \\.\PhysicalDrive X”其中X为驱动器的序号。(注意,C语言中\需要转义); 打开后会返回操作的句柄,就可以根据这个句柄进行操作了。关于CreateFile函数, 请点击这里查看 由于我们这里进行的是读取信息的操作,所以打开权限为“#GENERIC_READ”只读,同时将Flag置为:#OPEN_EXISTING,表示打开存在的。 这里需要注意一点, 如果CreateFile函数执行失败,返回值为:INVALID_HANDLE_VALUE,他的值为-1,而不是0; 【2】:进行过打开之后,就要获取硬盘的信息了,使用API函数:DeviceIoControl,关于更具体的使用方法,请参见MSDN,点击这里( 高能,英语不好者慎入 )。 使用“#IOCTL_DISK_GET_LENGTH_INFO”可以告知,我们将要获取磁盘的长度,也就是大小。 下面是具体分析: BOOL DeviceIoControl( (HANDLE) hDevice, // handle to device 句柄 IOCTL_DISK_GET_LENGTH_INFO, // dwIoControlCode 操作的代码 NULL, //忽略 0, //忽略 (LPVOID) lpOutBuffer, // output buffer 输出数据的缓冲区 (DWORD) nOutBufferSize, // size of output buffer 缓冲区的长度 (LPDWORD) lpBytesReturned, // number of bytes returned 可以忽略 (LPOVERLAPPED) lpOverlapped // OVERLAPPED structure 忽略 ); 复制代码 ps:上面这个“代码”编辑的功能还真是难用。 pOutBuffer 需要的是 GET_LENGTH_INFORMATION 结构体的地址(点击查看详情) ,在易语言中使用“长整数”即可,同时将该参数的DLL声明选中“传址”以完成传递地址。 使用“ 取数据类型尺寸 (#长整数型)”获取长整数在内存中占用的尺寸。并传递给参数: nOutBufferSize; 【3】完成上述操作后,只需要对 DeviceIoControl的返回值进行判断,如果为0则为失败调用取错误信息,然后释放句柄,函数返回。 如果获取成功,则返回长整数。 至此:函数运行完毕。
易语言API获取“物理硬盘”总大小 使用易语言进行硬盘操作,获取硬盘大小。 已经测试的操作系统:{ WINDOWS XP SP3 WINDOWS 7 X64 SP1 WINDOWS 2008 X64 } 其中包含的知识点: 【1】:CreateFile()打开物理驱动器操作,固定格式:“\\.\PhysicalDriveX”其中X为驱动器的序号。(注意,C语言中\需要转义); 打开后会返回操作的句柄,就可以根据这个句柄进行操作了。关于CreateFile函数,请点击这里查看 由于我们这里进行的是读取信息的操作,所以打开权限为“#GENERIC_READ”只读,同时将Flag置为:#OPEN_EXISTING,表示打开存在的。 这里需要注意一点,如果CreateFile函数执行失败,返回值为:INVALID_HANDLE_VALUE,他的值为-1,而不是0; 【2】:进行过打开之后,就要获取硬盘的信息了,使用API函数:DeviceIoControl,关于更具体的使用方法,请参见MSDN,点击这里(高能,英语不好者慎入)。 使用“#IOCTL_DISK_GET_LENGTH_INFO”可以告知,我们将要获取磁盘的长度,也就是大小。 下面是具体分析: BOOL DeviceIoControl( (HANDLE) hDevice,             // handle to device   句柄 IOCTL_DISK_GET_LENGTH_INFO,   // dwIoControlCode    操作的代码 NULL,                            //忽略 0,                                  //忽略 (LPVOID) lpOutBuffer,         // output buffer      输出数据的缓冲区 (DWORD) nOutBufferSize,      // size of output buffer   缓冲区的长度 (LPDWORD) lpBytesReturned,    // number of bytes returned    可以忽略 (LPOVERLAPPED) lpOverlapped   // OVERLAPPED structure       忽略 ); 复制代码 ps:上面这个“代码”编辑的功能还真是难用。 pOutBuffer 需要的是GET_LENGTH_INFORMATION结构体的地址(点击查看详情),在易语言中使用“长整数”即可,同时将该参数的DLL声明选中“传址”以完成传递地址。 使用“取数据类型尺寸 (#长整数型)”获取长整数在内存中占用的尺寸。并传递给参数:nOutBufferSize; 【3】完成上述操作后,只需要对DeviceIoControl的返回值进行判断,如果为0则为失败调用取错误信息,然后释放句柄,函数返回。 如果获取成功,则返回长整数。 至此:函数运行完毕。

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧