C/linux 產生隨機字符串


#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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM