ZwCreateFile创建文件

4.文件,注册表,线程

4.1文件操作内核并不接受用字符串来表示的文件路径,而是使用一个 OBJECT_ATTRIBUTES 未文档的结构,这个结构总是被 InitializeObjectAttributes 初始化.在内核中,无论是打开文件,注册表键,还是设备,都会这样初始化.

VOID InitializeObjectAttributes(

OUT POBJECT_ATTRIBUTES InitializedAttributes,//要初始化的 OBJECT_ATTRIBUTES结构的指针

IN PUNICODE_STRING ObjectName,//对象名字字符串(文件路径,如果打开的是文件的话)

IN ULONG Attributes,//填写 OBJ_CASE_INSENSITIVE(名字字符串不区分大小写) | OBJ_KERNEL_HANDLE(打开的是内核句柄) 即可方便简洁的打开,内核句柄比应用层句柄使用更方便,可以不受线程和进程的限制,在任何线程中读写,也不需要顾及权限问题.

IN HANDLE RootDirectory,//用于相对打开的情况,目前省略,传入 NULL 接口

IN PSECURITY_DESCRIPTOR SecurityDescriptor//设置安全描述符,如果是打开内核句柄,这里填写 NULL

);

打开文件:

ZwCreateFile(

_Out_ PHANDLE FileHandle,//返回打开文件的句柄指针,如果函数执行成功

_In_ ACCESS_MASK DesiredAccess,//申请的权限, FILE_WRITE_DATA(打开写文件) FILE_READ_DATA(读文件) DELETE(删除文件或改名) FILE_WRITE_ATTRIBUTES(设置写文件属性) FILE_READ_ATTRIBUTES(设置读文件属性),可以用 | 来组合

_In_ POBJECT_ATTRIBUTES ObjectAttributes,//对象描述,是 OBJECT_ATTRIBUTES 结构地址,包涵了要打开的文件名称

_Out_ PIO_STATUS_BLOCK IoStatusBlock,//结构 union 中的 Pointer 很少用,返回结构保存在 Status 中,更多信息在 Information,可能返回 FILE_CREATED(文件被成功的创建) FILE_OPENED(打开) FILE_OVERWRITTEN (覆盖) FILE_SUPERSEDED(替代) FILE_EXISTS (已存在) FILE_DOES_NOT_EXIST(不存在,所以打开失败)

_In_opt_ PLARGE_INTEGER AllocationSize,//指针,指向64位整数,定义文件初始分配的大小,这个参数仅关系到创建或重写文件操作,如果忽略,那么文件长度从0开始,并随着写入而增长.

_In_ ULONG FileAttributes,//控制新建文件属性,一般设置为0或者 FILE_ATTRIBUTE_NORMAL

_In_ ULONG ShareAccess,//共享访问设置,可以为 FILE_SHARE_READ FILE_SHARE_WRITE FILE_SHARE_DELETE,可组合,说明当本程序打开这个文件时其他程序可执行的操作.

_In_ ULONG CreateDisposition,//说明了这次打开的意图,不能组合,FILE_CREATE(新建) FILE_OPEN(打开) FILE_OPEN_IF(打开或新建) FILE_OVERWRITE(覆盖) FILE_OVERWRITE_IF (覆盖或新建) FILE_SUPERSEDE (取代或新建) 联系 IoStatusBlock 参数中的 Information 说明?

_In_ ULONG CreateOptions,//设置是否同步打开或者非同步打开?还有很多详细的说明什么的

_In_reads_bytes_opt_(EaLength) PVOID EaBuffer,

_In_ ULONG EaLength

);

说明太复杂,上个例子:

#include

VOID DriverUnload(PDRIVER_OBJECT driver){

}

NTSTATUS DriverEntry(PDRIVER_OBJECT driver, PUNICODE_STRING reg_path){

//驱动入口

UNICODE_STRING str = RTL_CONSTANT_STRING(L"KeAttachProcess");

DbgPrint("misaka: hello world , this is kernel driver ! %x\r\n", (ULONG)MmGetSystemRoutineAddress(&str));

//创建文件

//要返回的文件句柄

HANDLE file_handle = NULL;

//返回值

NTSTATUS status;

IO_STATUS_BLOCK io_status;

//先初始化含有文件路径的 OBJECT_ATTRIBUTES

OBJECT_ATTRIBUTES object_attributes;

UNICODE_STRING ufile_name = RTL_CONSTANT_STRING(L"\\??\\C:\\a.dat");//使用对象路径

InitializeObjectAttributes(&object_attributes, &ufile_name, OBJ_CASE_INSENSITIVE | OBJ_KERNEL_HANDLE, NULL, NULL);

//以 FILE_OPEN_IF 方式打开文件

status = ZwCreateFile(

&file_handle,

GENERIC_READ | GENERIC_WRITE,

&object_attributes,

&io_status,

NULL,

FILE_ATTRIBUTE_NORMAL,

FILE_SHARE_READ,

FILE_OPEN_IF,

FILE_NON_DIRECTORY_FILE | FILE_RANDOM_ACCESS | FILE_SYNCHRONOUS_IO_NONALERT,

NULL,

0

);

if (status == STATUS_SUCCESS){

DbgPrint("misaka: file create success \r\n");

}

else{

DbgPrint("misaka: file create failed %d\r\n",status);

}

ZwClose(file_handle);

driver->DriverUnload = DriverUnload;

return STATUS_SUCCESS;

}

执行结果:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容