0

0

C# 操作PowerShell模块文件 C#如何创建和解析.psd1和.psm1文件

幻夢星雲

幻夢星雲

发布时间:2026-02-21 10:20:03

|

302人浏览过

|

来源于php中文网

原创

powershell模块文件.psd1必须用powershell运行时解析,不可用c#直接读取;正确方式是引用microsoft.powershell.sdk,调用import-powershelldatafile并取baseobject获取hashtable,且需绝对路径、及时dispose。

c# 操作powershell模块文件 c#如何创建和解析.psd1和.psm1文件

PowerShell模块文件不是C#原生格式,别试图用File.ReadAllText直接解析.psd1

PSD1是PowerShell的哈希表序列化格式,本质是PowerShell代码(尽管看起来像JSON),C#没有内置解析器。直接读取再正则或JsonConvert.DeserializeObject会失败——ConvertFrom-StringData不适用,ConvertFrom-Json也报错,因为PSD1支持嵌套哈希、脚本块、类型标注(如[datetime]::Now)等非JSON语法。

正确路径只有一条:调用PowerShell运行时解析。别绕开它,也别写“轻量级PSD1解析器”,那只会漏掉@{Key='Value'; Nested=@{A=1}}Root = @{ PSModuleVersion = '1.2.3' }这类合法结构。

  • 必须引用 System.Management.Automation NuGet 包(v7+ 推荐用 Microsoft.PowerShell.SDK
  • 初始化 runspace 前先调用 [Powershell].Assembly.GetTypes() 触发自动加载,否则首次 PowerShell.Create() 可能卡住
  • PSD1 文件路径需用绝对路径传入,相对路径在 runspace 中默认以 PowerShell 工作目录为准,和 C# 当前目录无关

用PowerShell.Create().AddScript()安全加载.psd1并提取哈希表

不能用 Import-ModuleInvoke-Expression 加载 PSD1——它不是模块,是配置数据。正确做法是用 Import-PowerShellDataFile(v5.1+)或手动 Invoke-Expression + ConvertFrom-StringData 回退(不推荐)。v5.1 后应强制走 Import-PowerShellDataFile

SauceNAO
SauceNAO

SauceNAO是一个专注于动漫领域的以图搜图工具

下载
Powershell ps = PowerShell.Create();
ps.AddScript("Import-PowerShellDataFile -Path 'C:\mod\MyModule.psd1'");
var result = ps.Invoke();
if (ps.HadErrors) {
    throw new InvalidOperationException(string.Join("; ", ps.Streams.Error.Select(e => e.Exception.Message)));
}
Hashtable data = result[0].BaseObject as Hashtable; // 注意是 BaseObject,不是 ToString()
  • Import-PowerShellDataFile 会做安全检查,拒绝含命令、函数定义的 PSD1;若遇到被拒文件,说明它其实不是纯数据文件,而是伪装成 PSD1 的脚本
  • 返回对象是 PSObject,必须取 .BaseObject 才能得到原始 Hashtable,否则得到的是带属性包装的代理对象
  • PowerShell runspace 是有状态的,每次用完建议调用 ps.Dispose(),尤其在循环中反复加载多个 PSD1 时,否则内存泄漏明显

.psm1 是 PowerShell 脚本,C#只能执行不能“解析AST”

PSM1 不是可反编译的二进制,也不是 C# 能静态分析的源码。它本质是 .ps1 脚本,只是约定扩展名和加载方式不同。你无法用 C# 提取其中的函数签名、参数列表或注释帮助(.SYNOPSIS)。想“解析”,只有两条路:执行后反射导出,或调用 PowerShell 的 Get-CommandGet-Help

  • 加载 PSM1 必须用 Import-Module -Name 'C:path oModule.psm1' -Force,不能用 Invoke-Expression,否则函数不会注册进 session
  • 加载后执行 Get-Command -Module 'ModuleName' 获取导出函数列表,模块名默认取文件名(不含扩展名),但可通过 ModuleToProcess 在 PSD1 中覆盖
  • 若 PSM1 依赖其他模块,C# 中必须先确保那些模块已导入,PowerShell 不会自动解析 #requires 并下载——那是 Install-Module 的事,C# 不管

跨版本兼容性陷阱:PowerShell Core(pwsh)和 Windows PowerShell(powershell.exe)行为不同

Import-PowerShellDataFile 在 PowerShell 5.1 和 7+ 都存在,但 7+ 默认禁用 Invoke-Expression 类型的回退路径,且对 Unicode BOM、注释位置更严格。Windows PowerShell 允许 PSD1 末尾多一个逗号,pwsh 会直接报错 Unexpected token ',' in expression or statement

  • 生成 PSD1 时,务必用 Export-PowerShellDataFile(v5.1+)或手动拼接哈希表后调用 Out-File -Encoding UTF8NoBOM,避免记事本保存引入 BOM
  • C# 中判断当前环境:检查 Environment.GetEnvironmentVariable("PSModulePath") 是否含 powershell/7 路径,或运行 $PSVersionTable.PSVersion.Major 获取主版本号
  • 不要假设 PSModulePath 一定包含你的模块目录——C# 进程启动时 PowerShell 运行时可能还没初始化模块路径,需显式追加:$env:PSModulePath = 'C:mymodules;' + $env:PSModulePath

真正麻烦的从来不是怎么读,而是 PSD1 里那个看似无害的 @{ ScriptsToProcess = @('init.ps1') } ——它会让 Import-PowerShellDataFile 静默失败,除非你提前把 init.ps1 放到正确路径下。这种依赖链,C# 没法替你 resolve。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

443

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

322

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

329

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

773

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6404

2023.09.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

796

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.9万人学习

C 教程
C 教程

共75课时 | 4.9万人学习

C++教程
C++教程

共115课时 | 18.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号