我有很多这样的文件:
<Objs Version="1.1.0.1" xmlns="http://schemas.microsoft.com/powershell/2004/04">
<Obj RefId="0">
<TN RefId="0">
<T>System.Management.Automation.PSCredential</T>
<T>System.Object</T>
</TN>
<ToString>System.Management.Automation.PSCredential</ToString>
<Props>
<S N="UserName">mail.test@muzi.com</S>
<SS N="Password">01000000d08c93c76b9</SS>
</Props>
</Obj>
</Objs>我只需要提取邮件部分: mail.text@muzi.com,我知道我可以使用select-string,然后从char到char剪裁,我想找一个简单的一行,在每一个文件中找到邮件,然后修剪它。
$b = ($a | (select-string "username")).tostring()
$c = $b.trim(' ')以此类推。我确信有一条邮件可以从中提取,但我找不到它
发布于 2020-11-26 08:16:17
这似乎是一个具有密码的串行化 PowerShell (PSCredential)对象,该密码是伪造的(或在另一个帐户下创建的):
MethodInvocationException:使用"1“参数调用"Deserialize”的异常:“参数值"01000000d08c93c76b9”不是有效的加密字符串。“
正如您所发现的,如果数据来自一个文件:
$Credential = Get-Credential
$Credential | Export-Clixml .\Credential.xml您可以使用Import-Clixml cmdlet导入和反序列化对象:
$Credential = Import-clixml .\Credential.xml
$Credential.UserName
mail.test@muzi.com如果序列化字符串驻留在变量中(例如,$String):
$String = [System.Management.Automation.PSSerializer]::Serialize($Credential)您可以使用Deserialize方法反序列化字符串,如下所示:
[System.Management.Automation.PSSerializer]::Deserialize($String).Username
mail.test@muzi.com由于它是基于xml的,所以您也可以这样做:
([Xml]$String).Objs.Obj.Props.S.'#text'
mail.test@muzi.com请注意:使用string和/或方法以及
Select-String和-Replace直接查看和/或戳序列化数据通常是一种糟糕的方法。
https://stackoverflow.com/questions/65017919
复制相似问题