centos 欢迎字符串_Centos随机生成字符串 | 老王头

生成长度为32的随机字符串head -c 32 /dev/random | base64

该方式产生的随机数效果比较好,但是,当不能产生随机数时,它会阻塞在那里,也就是为阻塞程序的执行

用/dev/urandom文件产生

head -c 32 /dev/random | base64

该方式产生的随机数随机效果一般是,但是产生速度快,不会阻塞程序的运行

使用openssl方式openssl rand -hex 10

生成随机数:

echo RANDOM

32641

echoRANDOM

9753

echo $RANDOM

710

注:得到的这个随机数是介于 0~32767 之间的一个整数。

生成随机字符串

head -n 5 /dev/urandom |sed 's/[^a-Z0-9]//g'|strings -n 4

fEVNLfkm0PMSZfOtEIwaKbcMWLTk1

注:生成由a-Z和0-9组成的字符串。

openssl passwd -stdin 

5LYYPmuNIFS9c

head -n 5 /dev/urandom |strings -n 5

]bE&Op#P6C_\I[KC3Hn2,=$JfV5q{8tD)zG}Uw

注:

strings:

在对象文件或二进制文件中查找可打印的字符串。

语法:

语法

strings [ -a ] [ - ] [ -o ] [ -t Format ] [ -n Number ] [ -Number ] [ File … ]

参数:

-a 或 - 搜索整个文件,而不仅仅是数据段,以寻找可打印的字符串。如果省略这个标志,则 strings 命令只在对象文件的初始化数据空间内寻找。

-n Number 指定最小的字符串长度(除了缺省的 4 个字符以外)。字符串长度的最大值是 4096。这个标志与 -Number 标志相同。

-o 列出文件中每个跟随在其八进制偏移量之后的字符串。这个标志与 -t o 标志相同。

-t Format 列出从文件最开始起,每个跟随在其偏移量之后的字符串。该格式取决于用作 Format 变量的字符。

d

以十进制写下偏移量。

o

以八进制写下偏移量。

x

以十六进制写下偏移量。

注:当 -o 和 -t Format 标志在一个命令行上多次定义,则最后指定的标志控制 strings 命令的行为。

-Number 指定最小的字符串长度(除了缺省的 4 个字符以外)。字符串长度的最大值是 4096。这个标志与 -n Number 标志相同。

File 要搜索的二进制文件或对象文件。

退出状态

该命令返回以下退出值:

0 表示命令成功运行。

1 表示出错。

3、从指定字符集合中生成随机字符串:

!/bin/bash

MATRIX="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz~!@#%^&*()_+="LENGTH="9"while [ "{n:=1}" -le "LENGTH" ]doPASS="PASS{MATRIX:((RANDOM%{#MATRIX})):1}"let n+=1doneecho "$PASS"

exit 0

通过时间获得随机数(date)$date +%s%N

1287764807051101270

这个可以说比较完美了,加入了时间戳,又加上了纳秒

通过系统内部唯一数据生成随机数(/dev/random,urandom)[chengmo@centos5 shell]$head -1/dev/urandom

ãņù…•KTþçanVÕã¹Û&¡õ¾“ô2íùU“ žF¦_ ÿ”†mEðûUráÏ=J¯TŸA•ÌAÚRtÓ

读一行,怎么是乱码呢?其实它是通过二进制数据保存实时数据的,那么我们怎么样把它变成整型数据呢?

$head -200/dev/urandom | cksum

1615228479 50333

由于urandom的数据是非常多,不能直接通过cat读取,这里取前200行,其实整个数据都是变化的,取多少也一样是唯一的。

cksum 将读取文件内容,生成唯一的表示整型数据,只有文件内容不变,生成结果就不会变化,与php crc函数

读取linux 的uuid码$cat /proc/sys/kernel/random/uuid| cksum |cut -f1 -d" "

2141807556

你可能感兴趣的:(centos,欢迎字符串)