本文執行個體講述了PHP產生不重複標識符的方法。分享給大家供大家參考。具體實現方法如下:
產生唯一不重複的標識我們主要是根據當前的一個時間time然後再轉換在md5值,這樣幾乎是可以保證標籤的唯一性,下面整理了一些關於PHP產生不重複標識符程式碼,感興趣的朋友可以來看一下
PHP倒是內建了產生唯一id的函數:uniqid() ,它是基於目前時間微秒數的,用法如下:
複製代碼 代碼如下:
echo uniqid(); //13位的字串
echo uniqid("php_"); //當然你可以加上首碼
echo uniqid("php_", TRUE); //如果第二個參數more_entropy為true則產生23位字串
但是它產生的標識有可能不是唯一的,所以很多人會:
複製代碼 代碼如下:
<?php
//這是第一種簡單的方法,當然用sha1()函數也可以。
echo md5(uniqid());
//第二種,利用時間戳記的方法
echo md5(time() . mt_rand(1,1000000));
?>
例子:
複製代碼 代碼如下:
<?
//產生唯一識別碼
//sha1()函數, "安全散列演算法(SHA1)"
function create_unique() {
$data = $_SERVER['HTTP_USER_AGENT'] . $_SERVER['REMOTE_ADDR']
.time() . rand();
return sha1($data);
//return md5(time().$data);
//return $data;
}
?>
例子如下:
複製代碼 代碼如下:
<?php
$newhash = create_unique();
echo $newhash;
?>
我看到很多人使用 md5() 函數,即使它並不完全意味著這個目的:
複製代碼 代碼如下:
// generate unique string
echo md5(time() . mt_rand(1,1000000));
There is actually a PHP function named uniqid() that is meant to be used for this.
// generate unique string
echo uniqid();
/* prints
4bd67c947233e
*/
// generate another unique string
echo uniqid();
/* prints
4bd67c9472340
*/
你可能會注意到,儘管字串是唯一的,前幾個字元卻是類似的,這是因為產生的字串與伺服器時間相關。
但實際上也存在友好的一方面,由於每個新產生的 ID 會按字母順序排列,這樣排序就變得很簡單。
為了減少重複的機率,你可以傳遞一個首碼,或第二個參數來增加:
複製代碼 代碼如下:
// with prefix
echo uniqid('foo_');
/* prints
foo_4bd67d6cd8b8f
*/
// with more entropy
echo uniqid('',true);
/* prints
4bd67d6cd8b926.12135106
*/
// both
echo uniqid('bar_',true);
/* prints
bar_4bd67da367b650.43684647
*/
這個函數將產生比 md5() 更短的字串,節省一些空間。
php產生全球唯一識別碼(GUID)的方法
GUID在空間上和時間上具有唯一性,保證同一時間不同地方產生的數字不同。
世界上的任何兩台電腦都不會產生重複的 GUID 值。
需要GUID的時候,可以完全由演算法自動產生,不需要一個權威機構來管理。
GUID的長度固定,並且相對而言較短小,非常適合於排序、標識和儲存。
複製代碼 代碼如下:
<?php
//php產生GUID
function getGuid() {
$charid = strtoupper(md5(uniqid(mt_rand(), true)));
$hyphen = chr(45);// "-"
$uuid = substr($charid, 0, 8).$hyphen
.substr($charid, 8, 4).$hyphen
.substr($charid,12, 4).$hyphen
.substr($charid,16, 4).$hyphen
.substr($charid,20,12);
return $uuid;
}
?>
希望本文所述對大家的php程式設計有所協助。