shell编程中的md5sum以及随机数的创建

1. md5sum是什么

MD5 全称是报文摘要算法(Message-Digest Algorithm 5),此算法对任意长度的信息逐位进行计算,产生一个二进制长度为128位(十六进制长度就是32位)的“指纹”(或称“报文摘要”),不同的文件产生相同的报文摘要的可能性是非常非常之小的。

md5sum命令采用MD5报文摘要算法(128位)计算和检查文件的校验和。一般来说,安装了Linux后,就会有md5sum这个工具,直接在命令行终端直接运行。

Linux命令之md5sum
在网络传输、设备之间转存、复制大文件等时,可能会出现传输前后数据不一致的情况。这种情况在网络这种相对更不稳定的环境中,容易出现。那么校验文件的完整性,也是势在必行的。
md5sum命令用于生成和校验文件的md5值。它会逐位对文件的内容进行校验。是文件的内容,与文件名无关,也就是文件内容相同,其md5值相同
md5值是一个128位的二进制数据,转换成16进制则是32( 128/4 )位的进制值

md5校验,有很小的概本不同的文件生成的md5可能相同。比md5更安全的校验算法还有SHA*系列的
在网络传输时,我们校验源文件获得其md5sum,传输完毕后,校验其目标文件,并对比如果源文件和目标文件md5一致的话,则表示文件传输无异常。否则说明文件在传过程中未正确传输

2. 举例

[root@localhost md5sum]# date > data
[root@localhost md5sum]# cat data
Sat Feb 15 21:57:08 EST 2020
[root@localhost md5sum]# md5sum data
d0812de959953bbb0644b29c3a423ada  data
[root@localhost md5sum]# md5sum data |cut -d' ' -f1
d0812de959953bbb0644b29c3a423ada
[root@localhost md5sum]# 

在这里插入图片描述

[root@localhost md5sum]# ls
data  data1  data2  data3
[root@localhost md5sum]# md5sum *
d0812de959953bbb0644b29c3a423ada  data
f602f7bf882860efc88df88e0864336e  data1
0a4fd8b099ae157b4e52cc14bd154901  data2
f953a05af29851d2c596c188ffb720a5  data3
[root@localhost md5sum]# file data
data: ASCII text
[root@localhost md5sum]# md5sum -b data
d0812de959953bbb0644b29c3a423ada *data
[root@localhost md5sum]# 

将md5重定向到指定文件

[root@localhost md5sum]# md5sum data > data.md5
[root@localhost md5sum]# cat data.md5 
d0812de959953bbb0644b29c3a423ada  data
[root@localhost md5sum]# md5sum data
d0812de959953bbb0644b29c3a423ada  data
[root@localhost md5sum]# 

将多个文件的md5重定向或者追加到指定文件

[root@localhost md5sum]# md5sum * > d.md5
[root@localhost md5sum]# cat d.md5 
d0812de959953bbb0644b29c3a423ada  data
f602f7bf882860efc88df88e0864336e  data1
0a4fd8b099ae157b4e52cc14bd154901  data2
f953a05af29851d2c596c188ffb720a5  data3
2a892aa86403e1995cf36ec62f91416b  data.md5
[root@localhost md5sum]# ls
data  data1  data2  data3  data.md5  d.md5
[root@localhost md5sum]# 
[root@localhost md5sum]# md5sum data3 >> d.md5 
[root@localhost md5sum]# cat d.md5 
d0812de959953bbb0644b29c3a423ada  data
f602f7bf882860efc88df88e0864336e  data1
0a4fd8b099ae157b4e52cc14bd154901  data2
f953a05af29851d2c596c188ffb720a5  data3
2a892aa86403e1995cf36ec62f91416b  data.md5
f953a05af29851d2c596c188ffb720a5  data3
[root@localhost md5sum]# 

-c根据已经生成的md值,对现存文件校验
在这里插入图片描述

[root@localhost md5sum]# cat d.md5 
d0812de959953bbb0644b29c3a423ada  data
f602f7bf882860efc88df88e0864336e  data1
0a4fd8b099ae157b4e52cc14bd154901  data2
f953a05af29851d2c596c188ffb720a5  data3
2a892aa86403e1995cf36ec62f91416b  data.md5
f953a05af29851d2c596c188ffb720a5  data3
[root@localhost md5sum]# date >> data
[root@localhost md5sum]# md5sum -c d.md5 
data: FAILED
data1: OK
data2: OK
data3: OK
data.md5: OK
data3: OK
md5sum: WARNING: 1 computed checksum did NOT match
[root@localhost md5sum]# 

–status不生成提示信息,通过命令的返回值来判断

[root@localhost md5sum]# md5sum -c --status d.md5 
[root@localhost md5sum]# echo $?
1
[root@localhost md5sum]# 

3. shell中如何创建随机数

在这里插入图片描述在这里插入图片描述$RANDOM产生

[root@localhost md5sum]# echo $RANDOM
7575
[root@localhost md5sum]# echo $RANDOM
14127
[root@localhost md5sum]# echo $RANDOM
11277
[root@localhost md5sum]# 

结合字符串进行加密,写一个自己认识的密钥

[root@localhost md5sum]# echo "westos-yrx$RANDOM" |md5sum 
aa225b928a1646180ed9c1e12fddece4  -
[root@localhost md5sum]# echo "westos-yrx$RANDOM" |md5sum |cut -c 8-15
27479c08
[root@localhost md5sum]# 

openssl产生随机数
最后一位数字表示多少个比特

[root@localhost md5sum]# openssl rand -base64 8
qRE8+SYni6w=
[root@localhost md5sum]# openssl rand -base64 80
ZxZX6b5yzwJTjrSFjrryZifsrB4Biow+ifCVk9OjRCyKJ4Giev4wEfB6F6RyXlIU
0jO/zv8eal2b1aJz/kGeNySPu5WTWPg+UdTszOOPW48=
[root@localhost md5sum]# 

date产生

[root@localhost md5sum]# date +%s
1581823237
[root@localhost md5sum]# date +%s%N
1581823245378766270
[root@localhost md5sum]# 

date +%s //从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数(时间戳

date在显示方面,使用者可以设定欲显示的格式,格式设定为一个加号后接数个标记,其中可用的标记列表如下:
时间方面:

% : 印出 %
%n : 下一行
%t : 跳格
%H : 小时(00..23)
%I : 小时(01..12)
%k : 小时(0..23)
%l : 小时(1..12)
%M : 分钟(00..59)
%p : 显示本地 AM 或 PM
%r : 直接显示时间 (12 小时制,格式为 hh:mm:ss [AP]M)
%s : 从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数
%N:十亿分之一秒,纳秒 [000000000,999999999]
%S : 秒(00..61)
%T : 直接显示时间 (24 小时制)
%X : 相当于 %H:%M:%S
%Z : 显示时区

日期方面:

%a : 星期几 (Sun..Sat)
%A : 星期几 (Sunday..Saturday)
%b : 月份 (Jan..Dec)
%B : 月份 (January..December)
%c : 直接显示日期与时间
%d : 日 (01..31)
%D : 直接显示日期 (mm/dd/yy)
%h : 同 %b
%j : 一年中的第几天 (001..366)
%m : 月份 (01..12)
%U : 一年中的第几周 (00..53) (以 Sunday 为一周的第一天的情形)
%w : 一周中的第几天 (0..6)
%W : 一年中的第几周 (00..53) (以 Monday 为一周的第一天的情形)
%x : 直接显示日期 (mm/dd/yy)
%y : 年份的最后两位数字 (00.99)
%Y : 完整年份 (0000..9999)
[root@localhost md5sum]# date +%j
046
[root@localhost md5sum]# date +%x
02/15/2020
[root@localhost md5sum]# date +%U
06
[root@localhost md5sum]# date +%D
02/15/20
[root@localhost md5sum]# date +%A
Saturday
[root@localhost md5sum]# date +%X
10:24:34 PM
[root@localhost md5sum]# date +%T
22:24:45
[root@localhost md5sum]# date +%r
10:24:57 PM
[root@localhost md5sum]# 

4. 实战训练

在这里插入图片描述

[kiosk@foundation8 firefox]$ openssl rand -base64 40
Xl6h4nDyXJQwtIwQGCFNeO6sPBMWsMK9EVhsvySNLTjugtM+wJjaKg==
[kiosk@foundation8 firefox]$ openssl rand -base64 40 |sed 's/[^a-z]//g'
izjnzbnytzqrvlbcnurqpw
[kiosk@foundation8 firefox]$ openssl rand -base64 40 |sed 's/[^a-z]//g'|cut -c 2-11
omncdezywj
[kiosk@foundation8 firefox]$
[root@localhost practice]# sh 01.sh 
[root@localhost practice]# ls /westos/
ahlovfzacp_westos.html  hegegfqhea_westos.html  sbnxrfgkkn_westos.html
bnonstigyj_westos.html  iwtynghpeh_westos.html  ulkkljusud_westos.html
giympdvnpt_westos.html  jjutdxxnmv_westos.html
guttqayrqs_westos.html  ostnxjjqwy_westos.html
[root@localhost practice]# cat ~/practice/01.sh 
#!/bin/bash
Path=/westos
[ -d "$Path" ] || mkdir -p $Path   #判断该目录是否存在,不存在就创建
for n in `seq 10`
do
	random=$(openssl rand -base64 40 |sed 's/[^a-z]//g' |cut -c 2-11)
	touch $Path/${random}_westos.html
done

[root@localhost practice]# 
[kiosk@foundation8 firefox]$ seq 10
1
2
3
4
5
6
7
8
9
10
[kiosk@foundation8 firefox]$ seq -w 10
01
02
03
04
05
06
07
08
09
10
#!/bin/bash
user="westos"
passfile="/tmp/user.log"
for num in `seq -w 10` # num 依次为01 --- 10
do
        pass="`echo $RANDOM |md5sum |cut -c 3-11`" #密码
        useradd $user$num &> /dev/null && {
        echo "$pass" | passwd --stdin $user$num &> /dev/null
        echo -e "user: $user$num\tpasswd: $pass">> $passfile
}
if [ $? -eq 0 ];then
        echo "$user$num is ok"
else
        echo "$user$num is not ok"
fi
done
echo "#########################"
cat $passfile && >$passfile
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值