0x00 MD5 和 SHA-1

「MD5 消息摘要算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码散列函数,可以产生出一个 128位(16字节)的散列值(hash value),用于确保信息传输完整一致。MD5 由罗纳德·李维斯特设计,于1992年公开,用以替换 MD4 算法。这套算法的程序在 RFC 1321 中被加以规范。」

安全散列算法(英语:Secure Hash Algorithm,缩写为 SHA )是一个密码散列函数家族,是 FIPS 所认证的五种安全散列算法。能计算出一个数字消息所对应到的,长度固定的字符串(又称消息摘要)的算法。且若输入的消息不同,它们对应到不同字符串的概率很高。」

From WikiPedia

其实就是我懒得解释,因为反正你们也不在乎,我们直接上手。

MD5 和 SHA 通常被用作鉴别文件完整性和鉴别文件内容是否被修改

7.png8.png

本文面向普通用户,如果您有 Linux/Unix 使用经验,建议您直接关闭本篇文章

0x01 MD5

首先,大概 Terminal (终端),输入「md5」,然后把要计算的文件拖动到 Terminal 中,最终命名类似于 

$ md5 yourfile 

然后按下回车

1.png你会得到一串类似这样的文本

MD5 (yourfile) = MD5 Hash Code

后面就是得到的文件 MD5,文件比较大的话可能需要一定时间计算,这时只要安静的泡一杯茶就好。

如果你闲输出的内容烦得话,请直接使用

$ md5 -q yourfile 

这样会直接输出文件的 MD5 值。

那么如何计算字符串的 MD5 值呢?一些人可能会使用这样的方法

$ echo "String" | md5

2.png

也有些人会这样用

$ md5 <<<'String'

3.png你可以这样这样

$ md5 -qs 'String'

4.png

0x02 SHA

$ shasum yourfile

这条命令会帮你计算文件的SHA1

$ shasum -a 1 yourfile

6.png

这条命令会帮你计算文件的SHA1,同理,替换1为 224, 256, 384, 512, 512224, 512256 等等就会计算 SHA 224 balabala...

同理,我们可以使用

$ echo "String" | shasum
$ shasum <<<'String'

计算字符串的SHA1

也可以使用 

$ echo "String" | shasum -a 1
$ shasum -a 1 <<<'String'

来进行计算SHA balabala

0x03 OpenSSL Command Line Utilities

我们先来看看 openssl 命令支持的参数


Standard commands
asn1parse      ca             ciphers        crl            crl2pkcs7      
dgst           dh             dhparam        dsa            dsaparam       
ec             ecparam        enc            engine         errstr         
gendh          gendsa         genrsa         nseq           ocsp           
passwd         pkcs12         pkcs7          pkcs8          prime          
rand           req            rsa            rsautl         s_client       
s_server       s_time         sess_id        smime          speed          
spkac          verify         version        x509           

Message Digest commands (see the `dgst' command for more details)
md2            md4            md5            mdc2           rmd160         
sha            sha1           

Cipher commands (see the `enc' command for more details)
aes-128-cbc    aes-128-ecb    aes-192-cbc    aes-192-ecb    aes-256-cbc    
aes-256-ecb    base64         bf             bf-cbc         bf-cfb         
bf-ecb         bf-ofb         cast           cast-cbc       cast5-cbc      
cast5-cfb      cast5-ecb      cast5-ofb      des            des-cbc        
des-cfb        des-ecb        des-ede        des-ede-cbc    des-ede-cfb    
des-ede-ofb    des-ede3       des-ede3-cbc   des-ede3-cfb   des-ede3-ofb   
des-ofb        des3           desx           rc2            rc2-40-cbc     
rc2-64-cbc     rc2-cbc        rc2-cfb        rc2-ecb        rc2-ofb        
rc4            rc4-40         seed           seed-cbc       seed-cfb       
seed-ecb       seed-ofb       

所以,我们可以使用

$ openssl command [ command_opts ] [ command_args ] 

来进行 md5 ,sha1,balabala等等加密方式

我们只给几个例子,剩下的请自行研究

$ openssl md5 <<<"String"
$ openssl sha1 <<<"String"
5
1