Shell编程编程–安全加密安全加密
一、一、md5加密加密
1. 背景背景
在网络传输、设备之间转存、复制大文件等时,可能会出现传输前后数据不一致的情况。这种情况在网络这种相对更不稳定的
环境中,容易出现。那么校验文件的完整性,也是势在必行的。
md5sum命令用于生成和校验文件的md5值。它会逐位对文件的内容进行校验。是文件的内容,与文件名无关文件的内容,与文件名无关,也就是文件内容
相同,其md5值相同。
md5值是一个值是一个128位的二进制数据,转换成位的二进制数据,转换成16进制则是进制则是32((128/4)位的进制值。)位的进制值。
md5校验,有很小的概率不同的文件生成的md5可能相同。比md5更安全的校验算法还有SHA*系列的。
在网络传输时,我们校验源文件获得其md5sum,传输完毕后,校验其目标文件,并对比如果源文件和目标文件md5 一致的话,
则表示文件传输无异常。否则说明文件在传输过程中未正确传输。
2. 重要的选项重要的选项
选项选项 含义含义
-b 以二进制模式读入文件内容
-t 以文本模式读入文件内容
-c 根据已生成的md5值,对现存文件进行校验
--status
校验完成后,不生成错误或正确的提示信息,可以通过命令的返回值来判断。
3.生成文件生成文件md5值值
命令格式:
md5sum [选项] file
如:
[root@master lianxi]# md5sum data
0a6de444981b68d6a049053296491e49 data
[root@master lianxi]# md5sum *
0a6de444981b68d6a049053296491e49 data
13df384c47dd2638fd923f60c40224c6 data2
md5sum校验的是文件内容,与文件名无关
4.以文本模式或二进制模式读入文件并对其进行校验以文本模式或二进制模式读入文件并对其进行校验
-b 以二进制模式读入内容
-t 以文本模式读入文件内容进行校验
虽然是不同的读入模式,但是在进行求虽然是不同的读入模式,但是在进行求md5的时候,是一样的,因为是逐位校验的。的时候,是一样的,因为是逐位校验的。
如下文本文件,无论通过哪种模式读取md5都一致。
[root@master lianxi]# file data
data: ASCII text
[root@master lianxi]# md5sum data
0a6de444981b68d6a049053296491e49 data
[root@master lianxi]# md5sum -b data
0a6de444981b68d6a049053296491e49 *data
[root@master lianxi]# md5sum -t data
0a6de444981b68d6a049053296491e49 data
5.md5值重定向值重定向
将生成md5值重定向到指定的文件,通常文件的扩展名我们会命为.md5
如:
[root@master lianxi]# md5sum data > data.md5
[root@master lianxi]# md5sum data
0a6de444981b68d6a049053296491e49 data
[root@master lianxi]# cat data.md5
0a6de444981b68d6a049053296491e49 data
也可以将多个文件的md5重定向到指定的文件,每个文件的md5生成为一行