如何在终端将十六进制哈希转换为二进制?

问题描述

主要问题:如何使用xxd -r

次要详细信息。此命令输出一个十六进制哈希值:

openssl dgst -sha256 myFile |  awk '{print $2}' > myHashHex

我认为myHashHex一个“ hexdump”,不是吗?
我以为xxd -r < myHashHex会转换...嗯,它不起作用


注释

进行测试/比较。我认为这与二进制文件相同(没有标题):

openssl dgst -sha256 -binary myFile > myHashBin

因此,我希望xxd -r < myHashHex > newHashBin生成 newHashBin = myHashBin


PS:测试。现实生活中的问题是用sha256sum维护所有对象,并且只能在一个过程中将其转换为double-sha256。

相反,我使用openssl dgst -sha256 -binary myFile| openssl dgst -sha256 > myDoubleHash
我将使用两步过程:

  1. (总是产生myHashHex)
    openssl dgst -sha256 myFile | awk '{print $2}' > myHashHex

  2. (需要加倍时)xxd -r myHashHex | openssl dgst -sha256 > myDoubleHash

解决方法

十六进制转储的类型

问题在于xxd需要格式化的十六进制转储,但是您正在发送一串十六进制数字。这就是xxd所称的“普通hexdump”。

格式化的十六进制转储格式如下(约瑟夫·坎贝尔的报价):

$ printf "Computers are like old testament gods; lots of rules and no mercy." | xxd
00000000: 436f 6d70 7574 6572 7320 6172 6520 6c69  Computers are li
00000010: 6b65 206f 6c64 2074 6573 7461 6d65 6e74  ke old testament
00000020: 2067 6f64 733b 206c 6f74 7320 6f66 2072   gods; lots of r
00000030: 756c 6573 2061 6e64 206e 6f20 6d65 7263  ules and no merc
00000040: 792e                                     y.

xxd默认情况下会创建这种十六进制转储。

将-p用于十六进制字符串

根据xxd manpage-r希望读取格式化的十六进制转储:

-r | -revert
    reverse operation: ... 
    Use the combination -r -p to read plain hexadecimal 
    dumps without line number information and without a particular column layout. 
    ...

要重申,默认情况下,xxd -r需要格式化的十六进制转储。要使用xxd读取或写入“普通十六进制转储”,请使用-p选项。请注意,xxd期望标志位于参数之前,因此,如果以标志结尾,则会出现意外行为。

验证

如果您看到两次运行openssl(最初使用-binary)和使用xxd运行openssl会产生相同的结果。

$ openssl dgst -sha256 <( printf "Hello World!" ) |  awk '{print $2}' > myHashHex; 
$ xxd -r -p myHashHex | openssl dgst -sha256 
(stdin)= 61f417374f4400b47dcae1a8f402d4f4dacf455a0442a06aa455a447b0d4e170
$ openssl dgst -sha256 -binary <( printf "Hello World!" ) | openssl dgst -sha256
(stdin)= 61f417374f4400b47dcae1a8f402d4f4dacf455a0442a06aa455a447b0d4e170