2013-07-10 31 views

回答

2

假设你有XXDNC(netcat的)安装,可以[执行以下操作:

$ echo '0006303030304e43' | xxd -r -p | nc localhost 9998 
!0000ND007B44AC1DDEE2A94B0007-E000 

命令0006303030304e43被分解如下:

  • 0006 =十六进制的命令长度(即长度为0000NC
  • 30303030 = 4字节的报头十六进制
  • 4e43 = 2字节的命令NC十六进制

0000ND007B44AC1DDEE2A94B0007-E000! - 这是从HSM的响应。


如果你没有XXD,你可以使用Perl的

echo '0006303030304e43' | perl -e 'print pack "H*", <STDIN>' | nc localhost 9998 

更新1:一个更简单的解决方案:

echo -ne '\x00\x06\x30\x30\x30\x30\x4e\x43' | nc localhost 9998 

更新2:纯perl的解决方案:

perl -e 'use IO::Socket::INET; 
my $sock = new IO::Socket::INET(PeerAddr=>"localhost:9998") or die; 
$sock->send(pack "H*","0006303030304e43"); 
$sock->recv($data, 1024); print $data;' 

(只是复制并粘贴到您的bash提示符)

相关问题