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 通常被用作鉴别文件完整性和鉴别文件内容是否被修改


本文面向普通用户,如果您有 Linux/Unix 使用经验,建议您直接关闭本篇文章
0x01 MD5
首先,大概 Terminal (终端),输入「md5」,然后把要计算的文件拖动到 Terminal 中,最终命名类似于
$ md5 yourfile
然后按下回车
你会得到一串类似这样的文本
MD5 (yourfile) = MD5 Hash Code
后面就是得到的文件 MD5,文件比较大的话可能需要一定时间计算,这时只要安静的泡一杯茶就好。
如果你闲输出的内容烦得话,请直接使用
$ md5 -q yourfile
这样会直接输出文件的 MD5 值。
那么如何计算字符串的 MD5 值呢?一些人可能会使用这样的方法
$ echo "String" | md5

也有些人会这样用
$ md5 <<<'String'
你可以这样这样
$ md5 -qs 'String'

0x02 SHA
$ shasum yourfile
这条命令会帮你计算文件的SHA1
$ shasum -a 1 yourfile

这条命令会帮你计算文件的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"
