|
比如我在用php開發(fā)網(wǎng)站程序時(shí),為避免用戶同時(shí)多次打開同一個(gè)網(wǎng)頁(yè)導(dǎo)致session名稱沖突問題, 就希望保存的session不是$_SESSION['param'],而是$_SESSION[$luid]['param'],再通過其他方式傳遞$luid值,保證'param'參數(shù)不被覆蓋. 查找了一下別人的解決方式,都是生成UUID,而生成UUID的算法洋洋灑灑上百行. 我考慮到因?yàn)槭窃赟ESSION空間里,是一個(gè)受限定的環(huán)境,其唯一性的強(qiáng)度不必太高,只要在同一個(gè)SESSION的生存期限內(nèi)唯一就可以了,于是便有了下面的代碼:
復(fù)制代碼 代碼如下:
/**
* 返回一個(gè)唯一在本地系統(tǒng)中獨(dú)一無二的字符串,
* 返回的是32個(gè)字符的字符串,形式如'7dac352074f221f3edc74d265c65a636',或'd198d8fc56ffed627f3f8313d6f06acf'
*/
function LUID(){
return MD5(microtime());
}
其實(shí)就一行.return MD5(microtime());
按道理microtime()返回的字符串就已經(jīng)是唯一的了,我測(cè)了一下,即使連續(xù)執(zhí)行microtime(),返回值也有100us以上的差別,而使用者點(diǎn)擊,并在網(wǎng)絡(luò)上傳遞再由服務(wù)器處理的間隔遠(yuǎn)不止幾十ms. 加上md5只是讓結(jié)果雜亂化.
php技術(shù):php生成局部唯一識(shí)別碼LUID的代碼,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。