亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > PHP > 正文

PHP的偽隨機數與真隨機數詳解

2024-05-04 23:35:38
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了PHP的偽隨機數與真隨機數詳解,本文首先講解了真隨機數和偽隨機數的相關概念,并給出了比用mt_rand()函數產生更好的偽隨機數的一段例子代碼,需要的朋友可以參考下
 

首先需要聲明的是,計算機不會產生絕對隨機的隨機數,計算機只能產生“偽隨機數”。其實絕對隨機的隨機數只是一種理想的隨機數,即使計算機怎樣發展,它也不會產生一串絕對隨機的隨機數。計算機只能生成相對的隨機數,即偽隨機數。

偽隨機數并不是假隨機數,這里的“偽”是有規律的意思,就是計算機產生的偽隨機數既是隨機的又是有規律的。怎樣理解呢?產生的偽隨機數有時遵守一定的規律,有時不遵守任何規律;偽隨機數有一部分遵守一定的規律;另一部分不遵守任何規律。比如“世上沒有兩片形狀完全相同的樹葉”,這正是點到了事物的特性,即隨機性,但是每種樹的葉子都有近似的形狀,這正是事物的共性,即規律性。從這個角度講,你大概就會接受這樣的事實了:計算機只能產生偽隨機數而不能產生絕對隨機的隨機數。

首先來了解一下真隨機數和偽隨機數的概念。

真隨機數發生器:英文為:true random number generators ,簡稱為:TRNGs,是利用不可預知的物理方式來產生的隨機數。

偽隨機數發生器:英文為:pseudo-random number generators ,簡稱為:PRNGs,是計算機利用一定的算法來產生的。

對比一下兩種辦法產生的隨機數的圖片。

Random.org(利用大氣噪音來生成隨機數,而大氣噪音是空氣中的雷暴所產生的 )生成的隨機位圖:

PHP的偽隨機數與真隨機數詳解

Windows下PHP的rand()函數產生的隨機圖片:

PHP的偽隨機數與真隨機數詳解

很顯然,后者偽隨機數發生器產生的圖片有這明顯的條紋。

利用php的rand隨機函數產生這張圖片的代碼為:

復制代碼代碼如下:

//需要開啟gd庫
header("Content-type: image/png");
$im = imagecreatetruecolor(512, 512)
or die("Cannot Initialize new GD image stream");
$white = imagecolorallocate($im, 255, 255, 255);
for ($y=0; $y<512; $y++) {
for ($x=0; $x<512; $x++) {
if (rand(0,1) === 1) {
imagesetpixel($im, $x, $y, $white);
}
}
}
imagepng($im);
imagedestroy($im);

實際上也并不是所有的偽隨機數發生器(PRNGs)效果都這么差的,只是恰好在Windows下的PHP的rand()函數是這樣。如果是在Linux下 測試相同的代碼的話,所產生的圖片也看不出明顯的條紋。在Windows下如果用mt_rand()函數替代rand()函數的話效果也會好很多。這是由 于mt_rand()用了Mersenne Twister(馬其塞旋轉)算法來產生隨機數。PHP的文檔還說:mt_rand() 可以產生隨機數值的平均速度比 libc 提供的 rand() 快四倍。

 

另外,Linux內核(1.3.30以上)包括了一個隨機數發生器/dev/random ,對于很多安全目的是足夠的。

下面是關于Linux的隨機數發生器的原理介紹 :

Linux 操作系統提供本質上隨機(或者至少具有強烈隨機性的部件)的庫數據。這些數據通常來自于設備驅動程序。例如,鍵盤驅動程序收集兩個按鍵之間時間的信息,然后將這個環境噪聲填入隨機數發生器庫。

隨機數據存儲在 熵池 ( linux內核維護了一個熵池用來收集來自設備驅動程序和其它來源的環境噪音。理論上,熵池中的數據是完全隨機的,可以實現產生真隨機數序列。為跟蹤熵池中數據的隨 機性,內核在將數據加入池的時候將估算數據的隨機性,這個過程稱作熵估算。熵估算值描述池中包含的隨機數位數,其值越大表示池中數據的隨機性越好。 ) 中,它在每次有新數據進入時進行“攪拌”。這種攪拌實際上是一種數學轉換,幫助提高隨機性。當數據添加到熵池中 后,系統估計獲得了多少真正隨機位。

測定隨機性的總量是很重要的。問題是某些量往往比起先考慮時看上去的隨機性小。例如,添加表示自從上次按鍵盤以來秒數的 32 位數實際上并沒有提供新的 32 位隨機信息,因為大多數按鍵都是很接近的。

從 /dev/random 中讀取字節后,熵池就使用 MD5 算法進行密碼散列,該散列中的各個字節被轉換成數字,然后返回。

如果在熵池中沒有可用的隨機性位, /dev/random 在池中有足夠的隨機性之前等待,不返回結果。這意味著如果使用 /dev/random 來產生許多隨機數,就會發現它太慢了,不夠實用。我們經??吹?/dev/random 生成幾十字節的數據,然后在許多秒內都不產生結果。

幸運的是有熵池的另一個接口可以繞過這個限制:/dev/urandom。即使熵池中沒有隨機性可用,這個替代設備也總是返回隨機數。如果您取出許 多數而不給熵池足夠的時間重新充滿,就再也不能獲得各種來源的合用熵的好處了;但您仍可以從熵池的 MD5 散列中獲得非常好的隨機數!這種方式的問題是,如果有任何人破解了 MD5 算法,并通過查看輸出了解到有關散列輸入的信息,那么您的數就會立刻變得完全可預料。大多數專家都認為這種分析從計算角度來講是不可行的。然而,仍然認為 /dev/urandom 比 /dev/random 要“不安全一些”(并通常值得懷疑)。

Windows下沒有/dev/random可用,但可以使用微軟的“capicom.dll”所提供的CAPICOM.Utilities 對象。

以下是使用PHP時比用mt_rand()函數產生更好的偽隨機數的一段例子代碼:

復制代碼代碼如下:

<?php
// get 128 pseudorandom bits in a string of 16 bytes

 

$pr_bits = '';

// Unix/Linux platform?
$fp = @fopen('/dev/urandom','rb');
if ($fp !== FALSE) {
$pr_bits .= @fread($fp,16);
@fclose($fp);
}

// MS-Windows platform?
if (@class_exists('COM')) {
try {
$CAPI_Util = new COM('CAPICOM.Utilities.1');
$pr_bits .= $CAPI_Util->GetRandom(16,0);

// if we ask for binary data PHP munges it, so we
// request base64 return value. We squeeze out the
// redundancy and useless ==CRLF by hashing...
if ($pr_bits) { $pr_bits = md5($pr_bits,TRUE); }
} catch (Exception $ex) {
// echo 'Exception: ' . $ex->getMessage();
}
}

if (strlen($pr_bits) < 16) {
// do something to warn system owner that
// pseudorandom generator is missing
}
?>

 

所以PHP要產生真隨機數 還是要調用外部元素來支持的!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产欧美日韩免费看aⅴ视频| 久久久久久噜噜噜久久久精品| 中文字幕日韩欧美精品在线观看| 亚洲国产精品国自产拍av秋霞| 欧美激情二区三区| 91禁外国网站| 欧美二区在线播放| 成人精品视频99在线观看免费| 中文字幕国产亚洲| 中文字幕亚洲图片| 精品国产1区2区| 国产在线视频欧美| 成人综合网网址| 清纯唯美亚洲综合| 国产精品福利无圣光在线一区| 欧美精品在线极品| 国产成人鲁鲁免费视频a| 久久久电影免费观看完整版| 国产精品亚洲精品| 亚洲一区免费网站| 欧美www视频在线观看| 91av在线播放| 国产成人aa精品一区在线播放| 国产亚洲精品久久久久久牛牛| 国产精品免费福利| 中文字幕欧美专区| 97av在线影院| 国产一区二区三区免费视频| 久久久免费av| 亚洲国产精品一区二区三区| 国产综合在线观看视频| 国产一区二区丝袜| 亚洲香蕉成人av网站在线观看| 日韩欧美a级成人黄色| 国产精品小说在线| 孩xxxx性bbbb欧美| 欧美性猛交xxxx乱大交| 亚洲丝袜在线视频| 久久久最新网址| 国产一区二区丝袜高跟鞋图片| 国产精品久久久久久久久久尿| 久久久久久久久91| 国产精国产精品| 在线视频中文亚洲| 色妞色视频一区二区三区四区| 国产成人精品电影久久久| 91系列在线观看| 中文一区二区视频| 91免费在线视频| 久久天天躁日日躁| 国产又爽又黄的激情精品视频| 久久久久久久久久久成人| 成人午夜激情免费视频| 午夜精品久久久久久99热软件| 亚洲欧美精品一区二区| 91国偷自产一区二区三区的观看方式| 成人淫片在线看| 日韩中文字幕国产| 日韩黄色av网站| 欧美电影免费观看电视剧大全| 国产美女精品视频免费观看| 91久久国产综合久久91精品网站| 狠狠躁夜夜躁人人躁婷婷91| 日韩精品极品在线观看| 97人人做人人爱| 久久视频在线直播| 91精品久久久久久| 国产亚洲免费的视频看| 中文字幕国产亚洲| 欧美激情久久久久久| 亚洲国产精品大全| 777国产偷窥盗摄精品视频| 77777少妇光屁股久久一区| 菠萝蜜影院一区二区免费| 欧美日韩美女在线观看| 91干在线观看| 亚洲xxx大片| 中文字幕在线观看亚洲| 亚洲国内高清视频| 亚洲欧美日韩在线高清直播| 26uuu亚洲伊人春色| 国产视频999| 久久久爽爽爽美女图片| 国产亚洲精品久久久久久777| 国产精品视频xxx| 久久久久久91| 久久免费成人精品视频| 中文国产亚洲喷潮| 国产精欧美一区二区三区| 亚洲国产精品久久久久秋霞蜜臀| 亚洲欧美综合区自拍另类| 中文字幕国产亚洲| 欧美精品少妇videofree| 最新国产成人av网站网址麻豆| 欧美电影免费观看大全| 91在线观看欧美日韩| 久久久99久久精品女同性| 国产精品偷伦一区二区| 欧美性精品220| 久久久久久久久国产| 久久成年人免费电影| 欧美夫妻性生活xx| 国产福利视频一区二区| 久久视频这里只有精品| 国产精品中文在线| 欧美精品福利视频| 91精品久久久久久综合乱菊| 欧美在线www| 国产日韩欧美中文在线播放| 韩剧1988免费观看全集| 国内久久久精品| 亚洲人成电影在线| 一区二区三区日韩在线| 在线午夜精品自拍| 日韩欧美亚洲国产一区| 亚洲网站在线看| 欧美电影免费在线观看| 国产日韩精品在线| 欧美电影在线播放| 欧美中文字幕在线| 亚洲精品国产成人| 国产日韩欧美日韩大片| 久久人体大胆视频| 久久久伊人欧美| 久久精品久久久久电影| 久久夜色精品国产欧美乱| 色婷婷av一区二区三区久久| 国产成人精品在线| 亚洲伊人第一页| 午夜精品视频网站| 欧美激情视频一区二区三区不卡| 成人福利视频在线观看| 亚洲精品久久久久| 亚洲国产精品女人久久久| 7m第一福利500精品视频| 日本久久久久久久| 国产日韩欧美综合| 俺去亚洲欧洲欧美日韩| 亚洲欧美在线一区| 日韩国产一区三区| 日韩欧美中文字幕在线观看| 日韩精品中文字幕在线观看| 一区二区欧美久久| 亚洲日韩中文字幕| 亚洲精品综合久久中文字幕| 亚洲人成网站999久久久综合| 欧美亚洲国产成人精品| 日本成人免费在线| 精品调教chinesegay| 日韩在线观看电影| 欧美高跟鞋交xxxxhd| 国产成人高潮免费观看精品| 欧美亚洲在线观看| 97精品视频在线观看| 日韩av在线精品| 国产做受69高潮| 97国产一区二区精品久久呦| 一区二区国产精品视频| 欧美日韩一区二区三区在线免费观看| 久久影视电视剧免费网站| 在线观看国产成人av片| 亚洲影影院av| 亚洲精品影视在线观看| 欧洲亚洲在线视频|