我是 OSHI 的作者/主要维护者和 JNA 的提交者。 JNA 的 Platform 类不区分 Windows 和 Windows PE。OSHI 的代码依赖于标准的 Windows Version Helper API来确定操作系统对 DLL 函数的支持。但是,Windows PE 并未指示为单独的版本。
事实上,Windows PE 并非设计为独立的操作系统。它的目的(和授权使用)非常有限。来自Windows PE 文档(重点是我的):
Windows PE 不是通用操作系统。它不得用于部署和恢复以外的任何目的。
更远,
为防止将其用作生产操作系统,Windows PE 会在连续使用 72 小时后自动停止运行 shell 并重新启动。
本质上,Windows 10 API 中可用的某些功能在 PE 中不存在。从这些 Microsoft 文档中:
API 兼容性参考
Windows PE 是一个轻量级的引导操作系统,它基于 Windows 操作系统的组件子集。它旨在托管部署和恢复应用程序。因此,它包含许多 Windows 二进制文件,这些二进制文件需要托管对这些应用程序类最重要的 API。由于大小和其他设计限制,并非所有 Windows 二进制文件都存在于 Windows PE 中,因此并非所有 Windows API 都存在或可用。
这是 WinPE 的一项功能,而不是错误。
OSHI 被设计为提供信息的跨平台库。它不是一个“部署和恢复”应用程序。OSHI 链接(通过 JNA)到标准 Windows DLL,例如Kernel32
,而 WinPE 有自己的一组 MinCore DLL。
Windows PE 旨在非常轻量级,并且非常特定于 Windows 操作系统系列,并且非常特定于部署和恢复任务。
您可能应该使用命令行或Powershell工具来获取“部署和恢复”所需的操作系统和硬件信息,这是 WinPE 的唯一授权用途。OSHI 的ExecutingCommand
类是一个很好的实用程序类,用于将命令行响应作为 Java 字符串处理,欢迎您在自己的 Java 项目中复制和使用它,而不会产生整个 OSHI/JNA 依赖项的开销。
如果您可以指定“JNA 崩溃”的特定点,我可以帮助您确定解决可能引发的任何异常的方法。或者,您可以在 OSHI 项目中提交问题/功能请求以识别这些故障,以使其对 PE 环境更加健壮,尽管“更健壮”可能是“避免崩溃”的形式,而不是提供信息不能从 WinPE 中的 Windows API 获得。最后,您可以选择在 JNA 邮件列表中提出您的问题以进行扩展讨论。