#include <stdio.h> #include <string.h> #include <stdlib.h> #include <time.h> char* genRandomString(int length) { int flag, i; char* string; srand((unsigned) time(NULL )); if ((string = (char*) malloc(length)) == NULL ) { //myLog("Malloc failed!flag:14\n"); return NULL ; } for (i = 0; i < length - 1; i++) { flag = rand() % 3; switch (flag) { case 0: string[i] = 'A' + rand() % 26; break; case 1: string[i] = 'a' + rand() % 26; break; case 2: string[i] = '0' + rand() % 10; break; default: string[i] = 'x'; break; } } string[length - 1] = '\0'; return string; } int main() { char *buff; buff = genRandomString(50); printf("buff=%s\n",buff); free(buff); return 0; }
Linux下生成隨機數和隨機字符串
1、生成長度為32的隨機字符串
head -c 32 /dev/random | base64
1
該方式產生的隨機數效果比較好,但是,當不能產生隨機數時,它會阻塞在那里,也就是為阻塞程序的執行
2、用/dev/urandom文件產生
head -c 32 /dev/random | base64
1
該方式產生的隨機數隨機效果一般是,但是產生速度快,不會阻塞程序的運行
3、使用openssl方式
openssl rand -hex 10
1
4、生成隨機數:
[root@73 ~]# echo $RANDOM
32641
[root@73 ~]# echo $RANDOM
9753
[root@73 ~]# echo $RANDOM
710
1
2
3
4
5
6
注:得到的這個隨機數是介於 0~32767 之間的一個整數。
5、生成隨機字符串
a、[root@73 ~]# head -n 5 /dev/urandom |sed 's/[^a-Z0-9]//g'|strings -n 4
fEVN
Lfkm0
PMSZfO
tEIw
aKbc
MWLTk1
1
2
3
4
5
6
7
注:生成由a-Z和0-9組成的字符串。
b、[root@73 ~]# openssl passwd -stdin < <(echo)
5LYYPmuNIFS9c
c、[root@73 ~]# head -n 5 /dev/urandom |strings -n 5
]bE&O
p\#P6C
_\I[K
C3Hn2,=
$JfV5q
{8tD)
zG}Uw
1
2
3
4
5
6
7
8
9
10
11
注:
strings:
在對象文件或二進制文件中查找可打印的字符串。
語法:
語法
strings [ -a ] [ - ] [ -o ] [ -t Format ] [ -n Number ] [ -Number ] [ File ... ]
1
參數:
-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 要搜索的二進制文件或對象文件。
1
2
3
4
5
6
7
8
9
10
11
12
13
退出狀態
該命令返回以下退出值:
0 表示命令成功運行。
0 表示出錯。
3、從指定字符集合中生成隨機字符串:
#!/bin/bash
MATRIX="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz~!@#$%^&*()_+="
LENGTH="9"
while [ "${n:=1}" -le "$LENGTH" ]
do
PASS="$PASS${MATRIX:$(($RANDOM%${#MATRIX})):1}"
let n+=1
done
echo "$PASS"
exit 0
1
2
3
4
5
6
7
8
9
10
11
4、通過時間獲得隨機數(date)
[chengmo@centos5 shell]$date +%s%N
1287764807051101270
#這個可以說比較完美了,加入了時間戳,又加上了納秒
1
2
3
5、通過系統內部唯一數據生成隨機數(/dev/random,urandom)
[chengmo@centos5 shell]$head -1/dev/urandom
ãņù…•KTþçanVÕã¹Û&¡õ¾“ô2íùU“ žF¦_ ÿ”†mEðûUráÏ=J¯TŸA•ÌAÚRtÓ
1
2
讀一行,怎么是亂碼呢?其實它是通過二進制數據保存實時數據的,那么我們怎么樣把它變成整型數據呢?
[chengmo@centos5 ~/shell]$head -200/dev/urandom | cksum
1615228479 50333
1
2
3
由於urandom的數據是非常多,不能直接通過cat讀取,這里取前200行,其實整個數據都是變化的,取多少也一樣是唯一的。
cksum 將讀取文件內容,生成唯一的表示整型數據,只有文件內容不變,生成結果就不會變化,與php crc函數
6、讀取linux 的uuid碼
[chengmo@centos5 ~/shell]$cat /proc/sys/kernel/random/uuid| cksum |cut -f1 -d" "
2141807556
轉自:https://blog.csdn.net/wy1550365215/article/details/77446501