[内核驱动] DOS路径转化为NT路径
转载:http://blog.csdn.net/qq_33504040/article/details/78468278
最近在做一个文件过滤驱动程序,禁止访问指定目录或文件。想要从R3给R0发命令和想要禁止访问的路径,达到控制驱动的效果。
但是在R3下习惯使用DOS路径,就是显示磁盘分区的符号链接的路径,比如C:,D:\,但是在R0下一般拿到的都是设备名,卷名,类似于\Device\HarddiskVolume1\,这就代表这个计算机里的第一个分区也就是C盘,D盘之类的,那么在R3下与R0通讯,发送路径名时就需要转换。
一开始不了解的时候自己做了一个对应的表,类似于C盘对应\Device\HarddiskVolume1这种, 后来感觉会出问题,如果这个驱动在虚拟机上跑,大部分人一般虚拟机不分区,也就是只有一个C盘,然后系统会默认添加一个DVD光驱盘,这时肯定是添加D盘了,那如果后来又分了一个区比如是E盘,那么在我的表里面C D E分别对应 \Device\HarddiskVolume1,\Device\HarddiskVolume2 ,\Device\HarddiskVolume3,这时问题就来了,在这个计算机E盘对应的是\Device\HarddiskVolume2。而D盘对应的是\Device\CdRom0 ,如果按我的表来转换会出问题。
后来在网上查到了几个路径转换的函数,不知道他们面对的场景是不是跟我不一样,我拿来直接用转换有问题,没办法只能看了看内部实现,发现其实就一个重要的函数QueryDosDevice(),用这个函数可以查询盘符对应的卷名,那就很简单了,只需要截取字符串C: 然后调用函数返回\Device\HarddiskVolume1,再拼接上就OK了,相信大家稍微花点心思都可以写出来。
注意一下A B盘是没有的,过滤一下,这个问题我在网上查了一下,说是在电脑出现的早期,还没有硬盘和光驱,人们把应用程序和文件都存放在软盘上,就连启动电脑也主要靠软驱。当时,一台电脑通常会安装两个软驱,即3.5英寸和5.25英寸的两个软驱,他们就是所谓的“A盘”与“B盘”。后来硬盘产生后它们自然就被淘汰了。这里过滤一下。
然后还有一点就是控制面板的计算机管理那里是可以改磁盘的符号链接的,比如把C盘改成Y盘,但是它的设备名始终是唯一的,所以不影响结果。
#include <iostream>
#include <windows.h>
#include <tchar.h>
using namespace std; BOOL DeviceDosPathToNtPath(wchar_t* pDosPath, wchar_t* pNtPath)
{
static TCHAR DriveStr[MAX_PATH] = { };
static TCHAR DevName[MAX_PATH] = { };
TCHAR Drive[];
INT cchDevName;
INT i = ;
//检查参数
if (IsBadReadPtr(pDosPath, ) != )return FALSE;
if (IsBadWritePtr(pNtPath, ) != )return FALSE; if (!lstrcmpi(pDosPath, _T("A:\\")) || !lstrcmpi(pDosPath, _T("B:\\")))
return FALSE; Drive[] = pDosPath[i];
Drive[] = pDosPath[i + ];
Drive[] = '\0';
if (!QueryDosDevice(Drive, DevName, MAX_PATH))//查询设备名,这里是重点
return FALSE;
cchDevName = lstrlen(DevName);
lstrcpy(pNtPath, DevName);//复制设备名
lstrcat(pNtPath, pDosPath + );//复制路径
return TRUE;
} int main()
{
wchar_t* pDospath=L"C:\\Users\\Administrator\\Desktop\\test.txt";//盘符一定要指定一个存在的,比如你输入"K盘" ,这样转换会不成功
wchar_t Ntpath[MAX_PATH]; DeviceDosPathToNtPath(pDospath,Ntpath);
wprintf(L"NT : %s\n",Ntpath); getchar();
return ;
}
运行结果:
存在的盘符:
不存在的盘符:
[内核驱动] DOS路径转化为NT路径的更多相关文章
- 内核驱动编译之Makefile shell pwd路径问题
一般我们在写Makefile的时候为了获取到当前Makefile所在的文件夹路径,会使用TopDIR ?= $(shell pwd)来定义,后续的文件路径都是基于此TopDIR基础上使用. 今天在移植 ...
- NT路径,DOS路径和Device路径互相转换
项目中遇到的比较奇葩的问题,从网上找到一份源码,https://blog.csdn.net/qq125096885/article/details/70766206 稍微整理了下,VS可以直接编译 # ...
- linux内核驱动模型
linux内核驱动模型,以2.6.32内核为例.(一边写一边看的,有点乱.) 1.以内核对象为基础.用kobject表示,相当于其它对象的基类,是构建linux驱动模型的关键.具有相同类型的内核对象构 ...
- Unix/Linux环境C编程新手教程(12) openSUSECCPP以及Linux内核驱动开发环境搭建
1. openSUSE是一款优秀的linux. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaXRjYXN0Y3Bw/font/5a6L5L2T/font ...
- Unix/Linux环境C编程入门教程(12) openSUSECCPP以及Linux内核驱动开发环境搭建
1. openSUSE是一款优秀的linux. 2.选择默认虚拟机 3.选择稍后安装操作系统 4.选择linux opensuse 5. 选择默认虚拟机名称 6.设置处理器为双核. 7.内存设置为2 ...
- linux内核驱动——从helloworld开始
学习编程第一个都是学习hello world程序,学习内核驱动自然也不例外,我也是!本文整理了网上的一些资料以及加上自己的一些心得体会,希望对初学者有帮助,可别小看这个简单的hello world,本 ...
- Windows内核驱动中操作文件
本页主题:如何在windows内核驱动中对文件操作,实现对文件的拷贝.粘贴.删除.查询信息等,这是很常用也是很简单的方法. 部分内容参考:http://www.cppblog.com/aurain/a ...
- Windows内核驱动开发:HelloWorld
测试信息 Dev Machine: Windows Version: 2004 (19041.264) WDK Version: 10.0.19041.1 SDK Version: 10.0.1904 ...
- TCP数据接收及快速路径和慢速路径
概述 tcp握手完成后,收到数据包后,调用路径为tcp_v4_rcv->tcp_v4_do_rcv->tcp_rcv_established在tcp_rcv_established中处理T ...
随机推荐
- MACD 下0轴后,强力=7上0轴的实例:
MACD 下0轴后,强力=7上0轴的实例: 虽然再上0轴,但是由于是强力上,必须有缓解期.缓解期后MACD开始收口,虽然没有下0轴,但是开始趋向死叉. 由于并没有很强的做多市场环境,MACD只是略高于 ...
- mysql----------局域网数据库:如何让navicat链接局域网其他的数据库。
1.找到被链接的数据库,打开以后有一个自带的mysql数据库,打开以后下面有一个user表,把里面的第一条数据的第一个字段改成% 百分号,然后保存,重启数据库,搞定 2.如果是linux下的话,记得把 ...
- CSS position &居中(水平,垂直)
css position是个很重要的知识点: 知乎Header部分: 知乎Header-inner部分: position属性值: fixed:生成绝对定位的元素,相对浏览器窗口进行定位(位置可通过: ...
- uva11990 动态逆序对
这题说的是给了一个数组,按照他给的顺序依次删除数,在删除之前输出此时的逆序对个数 我们用Fenwick树 维护这整个数列, C[i]是一个 treap的头, 管理了在树状数组中 能影响他的点,然后我们 ...
- Python scrapy - Login Authenication Issue
https://stackoverflow.com/questions/37841409/python-scrapy-login-authenication-issue from scrapy.cra ...
- codeforces 979A Pizza, Pizza, Pizza!!!
题意: 对一个圆形的pizza,只能用直线来切它,求把它切为n+1份的形状和size都相同的最下次数. 思路: 形状和size都相同,那么只能是扇形,分奇偶讨论. n为0还得特判,切0刀,因为这个还被 ...
- 用python进行wifi密码生成
随着无线网络的不断发展,几乎所有场合都会覆盖WIFI信号,无论是公共地点还是家庭之中.众所周知,目前WIFI普遍的认证方式为wpa2,这种认证方式安全性相当不错,但由于人们设置密码时的随意性和固有思维 ...
- mitmproxy 中间人攻击的小玩笑
import mitmproxy.http from mitmproxy import ctx, http class Joker: def request(self, flow: mitmproxy ...
- 关于 redis、memcache、mongoDB 的对比 转
从以下几个维度,对 redis.memcache.mongoDB 做了对比.1.性能都比较高,性能对我们来说应该都不是瓶颈.总体来讲,TPS 方面 redis 和 memcache 差不多,要大于 m ...
- 计蒜客---N的-2进制表示
对于十进制整数N,试求其-2进制表示. 例如,因为 1*1 + 1*-2 + 1*4 + 0*-8 +1*16 + 1*-32 = -13 ,所以(-13)_10 = ( ...