需要帮助将文本文件中包含的所有十六进制字符转换为字符串或ASCII。十六进制字符以标准格式
显示user1 domain1 7374726f6e6770617373776f7264403130
user2 domain2 7374726f6e6770617373776f7264403120
转换后,它应显示为
user1 domain1 strongpassword@10
文本文件包含多个密码,所有密码都排成一行
答案 0 :(得分:2)
像这样:
$h = 7374726f6e6770617373776f7264403130
-join ($h -split '(..)' | ? { $_ } | % { [char][convert]::ToUInt32($_,16) })
答案 1 :(得分:2)
Get-Content file.txt | Foreach-Object{
$user,$domain,$pass = $_.Split()
$pass = for($i=0; $i -lt $pass.length; $i+=2)
{
[char][int]::Parse($pass.substring($i,2),'HexNumber')
}
$user,$domain,(-join $pass) -join ' '
}
答案 2 :(得分:1)
这是如何做到这一点的例子:
$text = 'user1 domain1 7374726f6e6770617373776f7264403130'
$p = [Regex]::Match($text, '\w+$').Value
$pass = ((0..(($p.length - 1) / 2) | % {[Char]([Convert]::toint16($p.SubString($_ * 2, 2), 16))}) -Join '')
$text = $text -Replace '\w+$', $pass
$text
答案 3 :(得分:0)
$pass=""
$t="7374726f6e6770617373776f7264403130"
$t -split '(.{2})' |%{ if ($_ -ne "") { $pass+=[CHAR]([CONVERT]::toint16("$_",16)) }}
write host $pass
答案 4 :(得分:0)
第一个响应是唯一一个返回该行的用户,域,和密码十六进制解码。
第二个反应是优雅中最像Perl的。
以下是两者的组合:
[regex]$regEx = '(\S+)$';
$scriptBlock = { param ($match); -join ( $match.Groups[1].Value -split '(..)' | ? { $_; } | % { [Char]( [Convert]::ToInt16($_, 16) ); } ); }
Get-Content file.txt | % { $regEx.Replace($_, $scriptBlock); }
可以格式化scriptblock以提高可读性,而不是简洁/类似Perl的混淆。 :)
$scriptBlock = {
param ($match);
-join (
$match.Groups[1].Value -split '(..)' | ? { $_; } | % {
[Char]( [Convert]::ToInt16($_, 16) );
}
);
};
答案 5 :(得分:0)
另一种选择。这样做的好处是可以为您提供一个可以使用Format-Table查看或使用Export-Csv导出的对象。此外,这里的ConvertForm-Hexadecimal实现速度非常快,即使使用非常大的字符串也能正常工作。
function ConvertFrom-Hexadecimal([string] $hexString)
{
[byte[]] $data = @()
if ([string]::IsNullOrEmpty($hexString) -eq $true -or $hexString.Length % 2 -ne 0)
{
throw New-Object FormatException("Hexadecimal string must not be empty and must contain an even number of digits to be valid.");
}
$hexString = $hexString.ToUpperInvariant()
$data = New-Object byte[] -ArgumentList ($hexString.Length / 2)
for ([int] $index = 0; $index -lt $hexString.Length; $index += 2)
{
[int] $highDigitValue = if ($hexString[$index] -le ([char] '9')) { $hexString[$index] - ([char] '0') } else { $hexString[$index] - ([char] 'A') + 10 }
[int] $lowDigitValue = if ($hexString[$index + 1] -le ([char] '9')) { $hexString[$index + 1] - ([char] '0') } else { $hexString[$index + 1] - ([char] 'A') + 10 }
if ($highDigitValue -lt 0 -or $lowDigitValue -lt 0 -or $highDigitValue -gt 15 -or $lowDigitValue -gt 15)
{
throw New-Object FormatException("An invalid digit was encountered. Valid hexadecimal digits are 0-9 and A-F.")
}
else
{
[byte] $value = [byte](($highDigitValue -shl 4) -bor ($lowDigitValue -band 0x0F))
$data[$index / 2] = $value;
}
}
return ,$data
}
$fileName = '.\testfile.txt'
$passwordColumn = @{ name = 'Password'; expression = { $bytes = ConvertFrom-Hexadecimal $_.EncodedPassword; [System.Text.Encoding]::ASCII.GetString($bytes); } }
$users = Import-Csv -Delimiter ' ' -Header User, Domain, EncodedPassword -Path $fileName | Select *, $passwordColumn
$users | ft -AutoSize
答案 6 :(得分:0)
$IN="SOME LONG CRAZY STRING TO CONVERT TO HEX"
$HEX = $(($IN | Format-Hex).ToString().Split("`n")).ForEach({ $_.remove(0,11) -replace '[ ]{2,}.*$','' }).Split() -join ''
Write-Host $HEX
$OUT = $($HEX -split '(.{2})').ForEach({ if ($_ -ne "") { [CHAR]([CONVERT]::toint16("$_",16)) } }) -join ''
Write-Host $OUT