【问题标题】:Virtual Drive Mapped to Program映射到程序的虚拟驱动器
【发布时间】:2011-10-19 14:46:22
【问题描述】:

是否可以创建一个程序(最好是.NET)来创建一个虚拟驱动器号,但是当它被读取、写入或浏览时,一个独立的程序会处理返回的内容?

虽然您可以通过将驱动器映射到 TCP 服务器、webDAV 或类似的东西来做到这一点,但我想知道是否可以通过内部链接来完成。

这将用于受保护的存储。如果程序已输入密码,该程序会对驱动器中的所有文件进行流式加密和解密(因为它们被各种程序读取)。

【问题讨论】:

  • 您更多的是寻找设备驱动程序而不是程序
  • 怀疑在 .Net 中完全有可能。查看类似问题:stackoverflow.com/questions/138080/emulate-hard-disk-in-net
  • 有一个驱动程序转发到用户空间程序以进行文件系统操作。不过不知道有没有免费的。
  • 但我不想为了加密而这样做。加密程序需要低级功能,例如在休眠时卸载,或防止密钥交换到磁盘。使用这种方法也可能无法加密系统分区。你为什么不直接使用 TrueCrypt 呢?
  • @CodeInChaos 我不想使用 TrueCrypt,因为我想知道它到底是如何工作的。可能甚至不会使用它,只是想知道。

标签: c# .net c++ windows shell


【解决方案1】:

您所说的是存储设备驱动程序,它是 Daemon Tools 和 TrueCrypt 等程序如何完成这种“虚拟”驱动程序的。

不过,您可能不必深入内核来完成此操作。 Microsoft 提供了一个 Windows 用户模式驱动程序框架,旨在简化某些常见 Windows 驱动程序类型的开发。据我所知,您应该能够使用用户模式驱动程序框架开发虚拟存储驱动程序。只要您不直接与硬件交互(就像内核模式设备驱动程序那样),您应该没问题。但是,您将无法在 C# 中执行此操作。您可能不得不使用 C,尽管您可能会使用 C++。

【讨论】:

  • 干杯人,听起来不错。您不会碰巧知道有任何参考资料显示这种设备的基本代码作为起点吗?
  • OSR Online 是一个很棒的 Windows 驱动程序开发社区。您可能还想查看 Mark Russinovich 的 Windows Internals 5,以获取有关 Windows 内核内部的非常详细的背景信息。只需在 Google 上快速搜索“Windows 驱动程序开发”即可。
【解决方案2】:

PowerShell 的 Provider 模型已经支持类似的东西。证书存储、Active Directory、IIS 配置、SharePoint 等都被制作成类似于文件系统,使用相同的命令进行查询和更新。

这是 PowerShell 的核心。 $foo 是变量foo 的值,${c:\foo.txt} 是文件C:\foo.txt 的内容,但就像变量一样使用。同样,dir HKLM:\Software 列出了该注册表项的子项。

您可以编写自己的提供程序。

【讨论】:

  • 这不是和他的要求相反吗?即获取现有设备并将其制成文件,而不是获取现有文件并将其变成设备。
  • @Polynomial 否。提供者可以获取文件并使其看起来像一个完整的文件系统。有一个提供程序可以跨 IE 的 RSS 支持工作 - IE 数据文件夹中的一系列文件被转换为更用户的格式(FeedStore 提供程序是 PSCX 的一部分)。
【解决方案3】:

有一个开源程序WinCDEmu 可以将 ISO 映像挂载到虚拟驱动器。我想您将能够检查资源以找出如何提供一个虚拟驱动器来满足您的需求。该项目是用 C++ 编写的。

它基于BazisLib,这是一个简化windows驱动开发的框架。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-09-25
    • 2017-03-28
    • 1970-01-01
    • 1970-01-01
    • 2018-01-16
    • 2011-05-28
    相关资源
    最近更新 更多