zoukankan      html  css  js  c++  java
  • Windows 驱动发展基金会(九)内核函数

    Windows 驱动发展基金会系列,转载请注明出处:http://blog.csdn.net/ikerpeng/article/details/38849861


    这里主要介绍3类Windows的内核函数:字符串处理函数,文件操作函数, 注冊表读写函数。

    这些函数都是执行时函数,所以都有Rtl字样


    1 字符串处理函数

    首先驱动程序中,经常使用的字符串包含4种:CHAR (打印的时候注意小写%s), WCHAR(打印的时候注意大写%S), ANSI_STRING, UNICODE_STRING。后面两种使用的比較的多注意他们两都不是以0标志结束的。


    使用前要都要进行初始化(就像C里面的变量声明和赋值)。

    都有其对应的初始化函数:

    RtlInitAnsiString(),RtlInitUnicodeString()。使用的样例:

    ANSI_STRING ansiString;

    CHAR* string = “Hello”;

    RtlInitAnsiString(&ansiString, string);

    同理我们还有对应的:复制:RtlCopyString()RtlCopyUnicodeString()比較:RtlCompareUnicodeString()RtlCompareString()转化为大写:RtlUpperString() RtlUpcaseUnicodeString()转化为整型:RtlUnicodeStringtoInteger()整型转化为Unicode RtlIntegertoUnicodeString()。

    详细用到的时候查手冊就好。


    2. 文件操作函数

    文件的操作主要包含:文件的创建,打开,改动。读。写等的操作。

    这个文件操作的基本公用代码是:

        UNICODE_STRING string;

        RtlInitUnicodeString(&string, L"\??\C:\1.log");

        OBJECT_ATTRIBUTES objattr;

        InitializeObjectAttributes(&objattr, &string, OBJ_CASE_INSENSITIVE, NULL, NULL);

        HANDLE hFile;

        IO_STATUS_BLOCK iostatus;

    以上就是对于函数要调用的一些參数的申明和定义。接下来就能够对创建的文件进行操作勒。

    操作的函数主要有:


    文件的创建: ZwCreativeFile()文件属性设置:ObjectAttributes()文件的打开:ZwOpenFile() 文件的信息获取 ZwSetInformationFile(),改动属性ZwQueryInformationFile()文件的读 ZwReadFile()文件的写 ZwWriteFile()。


    3.注冊表

    注冊表中存储的是对个的二元结构:键名--键值;同一时候一个注冊表项可能还存在他的子项。

    其操作和文件的操作非常像。基本的函数有ZwCreatKey(),ZwOpenKey(),ZwSetValueKey()(键值)ZwQueryValueKey()ZwQueryKey()(键名的操作)等等。


    本小节完。


    參考文献

    《 Windows 驱动开发技术详细说明 》

    版权声明:本文博主原创文章。博客,未经同意不得转载。

  • 相关阅读:
    openwrt 的依赖找不到问题
    数据包与IPTABLE关系
    wifidog 配置中文说明
    Java 线程
    Java 集合
    IDEA配置Maven并创建web项目
    逻辑覆盖
    获得天气数据
    小程序项目文件介绍
    window 10 使用git
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4852456.html
Copyright © 2011-2022 走看看