UUID(Universally Unique Identifier),GUID都是希望在整個時空范圍內能產生唯一識別碼,這在分布式計算環境下是必要的. 然而,如果僅僅是想在一個受限定的局部環境下,想生成一個"局部唯一識別碼",使用UUID就是殺雞用牛刀,這個"局部唯一識別碼",我稱之為LUID(Local Unique Identifier)
比如我在用php開發網站程序時,為避免用戶同時多次打開同一個網頁導致session名稱沖突問題, 就希望保存的session不是$_SESSION['param'],而是$_SESSION[$luid]['param'],再通過其他方式傳遞$luid值,保證'param'參數不被覆蓋. 查找了一下別人的解決方式,都是生成UUID,而生成UUID的算法洋洋灑灑上百行. 我考慮到因為是在SESSION空間裡,是一個受限定的環境,其唯一性的強度不必太高,只要在同一個SESSION的生存期限內唯一就可以了,於是便有了下面的代碼:
復制代碼 代碼如下:
/**
* 返回一個唯一在本地系統中獨一無二的字符串,
* 返回的是32個字符的字符串,形式如'7dac352074f221f3edc74d265c65a636',或'd198d8fc56ffed627f3f8313d6f06acf'
*/
function LUID(){
return MD5(microtime());
}
其實就一行.return MD5(microtime());
按道理microtime()返回的字符串就已經是唯一的了,我測了一下,即使連續執行microtime(),返回值也有100us以上的差別,而使用者點擊,並在網絡上傳遞再由服務器處理的間隔遠不止幾十ms. 加上md5只是讓結果雜亂化.