天天看点

Shell编程之安全加密

linux之md5sum

在网络传输、设备之间转存、复制大文件等时,可能会出现传输前后数据不一致的情况。这种情况在网络这种相对更不稳定的环境中,容易出现。那么校验文件的完整性,也是势在必行的。

    md5sum命令用于生成和校验文件的md5值。它会逐位对文件的内容进行校验。是文件的内容,与文件名无关,也就是文件内容相同,其md5值相同。md5值是一个128位的二进制数据,转换成16进制则是32(128/4)位的进制值。

    md5校验,有很小的概率不同的文件生成的md5可能相同。比md5更安全的校验算法还有SHA*系列的。

    在网络传输时,我们校验源文件获得其md5sum,传输完毕后,校验其目标文件,并对比如果源文件和目标文件md5 一致的话,则表示文件传输无异常。否则说明文件在传输过程中未正确传输。

 重要的选项

  • -b 以二进制模式读入文件内容
  • -t 以文本模式读入文件内容
  • -c 根据已生成的md5值,对现存文件进行校验
  • --status 校验完成后,不生成错误或正确的提示信息,可以通过命令的返回值来判断。

linux产生随机数的方法

1)使用系统变量$RANDOM 0-32767 加密性不好,利用md5sum并截取需要的位数

echo "$RANDOM" |md5sum|cut -c 1-8

2)通过openssl产生随机数

openssl rand -base64 8

3)通过时间date 获得随机数 

date +%s%N %s从linux系统开始到现在的秒数,%N纳秒

4)通过UUID生成随机数

UUID全称为通用唯一识别码(Universally Unique Identifier,UUID)

是一个软件建构的标准,亦为自由软件基金会Open Software Foundation OSF

的组织在分布式计算环境Distributed Computin Environment DCE领域的一部分

    cat /proc/sys/kernel/random/uuid

5)expect附带的mkpasswd生成

    mkpasswd命令依赖于expect 必须安装

    mkpasswd -l 9 -d 2 -c 3 -C 3 -s 1

    -l 指定密码长度   默认为9   length

    -d 指定密码中的数字数量  默认为2   digits

    -c 指定密码中小写字母的数量     默认为2    lowercase chars

    -C 指定密码中大写字母的数量     默认为2        upper chars

    -s 指定密码中的特殊字符数量     默认为1        special chars

以上都必须有