
bash Linux スクリプトがあります:
echo -e '\x55\x55\xaa\xaa\x00\x00\x00\x00\x00\x00\x00\x50' | netcat -w 2 192.168.10.187 8000
今、これを PowerShell に変換しようとしていますが、この文字列の echo の構文が何であるかわかりません。
私がただやる時:
echo '\x55\x55\xaa\xaa\x00\x00\x00\x00\x00\x00\x00\x50' | & .\nc -w 2 192.168.10.187 8000
nc
結果は得られませんが、文字列がパイプされているかどうか、または間違った文字列であるかどうかはわかりません。
答え1
バイトをチェックするには、Format-Hex コマンドレットを使用します。
PS > $bytes = [Byte[]] (0x55,0x55,0xaa,0xaa,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x50)
PS > $bytes | Format-Hex
Path:
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000 55 55 AA AA 00 00 00 00 00 00 00 50 UUªª.......P
答え2
出力の制限により、Powershell では実行できないようなので、小さな C# アプリを作成しました。
using (var stdout = Console.OpenStandardOutput())
{
var buffer = new Byte[]
{
0x55,
0x55,
0xaa,
0xaa,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x50
};
stdout.Write(buffer, 0, buffer.Length);
}