如何在PHP中创建唯一键值?
我需要长度为20位(不超过33位)的简单唯一键。
答案 0 :(得分:6)
您正在寻找加密密钥?
请勿在涉及安全性的任何环境中使用uniqid()
。在这种情况下使用它是太可预测的了。
PEAR::Crypt_RSA包允许您在PHP中生成加密强密钥。一旦安装在本地PEAR安装中,您可以使用它来生成密钥,如下所示:
require_once 'Crypt/RSA.php';
// Creates a 96-bit key, which is 24 hex chars long
$key_pair = new Crypt_RSA_KeyPair(96);
//Returns public key from the pair
$public_key = $key_pair->getPublicKey();
//Returns private key from the pair
$private_key = $key_pair->getPrivateKey();
UUID也可能对您的目标有益。这是一个将在所有系统上生成符合标准的UUID的类:
<?php
/**
* UUID generator class
*
* Generates valid RFC 4211 compliant Universally Unique IDentifiers (UUID) version 3, 4 and 5.
* UUIDs generated validate using the OSSP UUID Tool, and the output for named-based UUIDs are
* exactly the same. This is a pure PHP implementation.
*
* Usage:
*
* Name-based UUID:
*
* $v3uuid = UUID::v3('1546058f-5a25-4334-85ae-e68f2a44bbaf', 'SomeRandomString');
* $v5uuid = UUID::v5(UUID::NS_URL, 'http://www.google.com/');
*
* Pseudo-random UUID:
*
* $v4uuid = UUID::v4();
*
*
* Originally found at: http://www.php.net/manual/en/function.uniqid.php#94959
*
* @author Andrew Moore
*
*
* Modifications made by Henry Merriam <php@henrymerriam.com> on 2009-12-20:
*
* + Added constants for predefined namespaces as defined in RFC 4211 Appendix C.
* + NS_DNS
* + NS_URL
* + NS_ISO_UID
* + NS_X500_DN
*
* + Wrote this documentation comment.
*
*/
class UUID {
const NS_DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8'; // FQDN
const NS_URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8'; // URL
const NS_ISO_OID = '6ba7b812-9dad-11d1-80b4-00c04fd430c8'; // ISO OID
const NS_X500_DN = '6ba7b814-9dad-11d1-80b4-00c04fd430c8'; // X.500 DN (in DER or a text output format)
public static function v3($namespace, $name) {
if(!self::is_valid($namespace)) return false;
// Get hexadecimal components of namespace
$nhex = str_replace(array('-','{','}'), '', $namespace);
// Binary Value
$nstr = '';
// Convert Namespace UUID to bits
for($i = 0; $i < strlen($nhex); $i+=2) {
$nstr .= chr(hexdec($nhex[$i].$nhex[$i+1]));
}
// Calculate hash value
$hash = md5($nstr . $name);
// Format and return UUID
return sprintf('%08s-%04s-%04x-%04x-%12s',
// 32 bits for "time_low"
substr($hash, 0, 8),
// 16 bits for "time_mid"
substr($hash, 8, 4),
// 16 bits for "time_hi_and_version",
// four most significant bits holds version number 3
(hexdec(substr($hash, 12, 4)) & 0x0fff) | 0x3000,
// 16 bits, 8 bits for "clk_seq_hi_res",
// 8 bits for "clk_seq_low",
// two most significant bits holds zero and one for variant DCE1.1
(hexdec(substr($hash, 16, 4)) & 0x3fff) | 0x8000,
// 48 bits for "node"
substr($hash, 20, 12)
);
}
public static function v4() {
return sprintf('%04x%04x-%04x-%04x-%04x-%04x%04x%04x',
// 32 bits for "time_low"
mt_rand(0, 0xffff), mt_rand(0, 0xffff),
// 16 bits for "time_mid"
mt_rand(0, 0xffff),
// 16 bits for "time_hi_and_version",
// four most significant bits holds version number 4
mt_rand(0, 0x0fff) | 0x4000,
// 16 bits, 8 bits for "clk_seq_hi_res",
// 8 bits for "clk_seq_low",
// two most significant bits holds zero and one for variant DCE1.1
mt_rand(0, 0x3fff) | 0x8000,
// 48 bits for "node"
mt_rand(0, 0xffff), mt_rand(0, 0xffff), mt_rand(0, 0xffff)
);
}
public static function v5($namespace, $name) {
if(!self::is_valid($namespace)) return false;
// Get hexadecimal components of namespace
$nhex = str_replace(array('-','{','}'), '', $namespace);
// Binary Value
$nstr = '';
// Convert Namespace UUID to bits
for($i = 0; $i < strlen($nhex); $i+=2) {
$nstr .= chr(hexdec($nhex[$i].$nhex[$i+1]));
}
// Calculate hash value
$hash = sha1($nstr . $name);
// Format and return UUID
return sprintf('%08s-%04s-%04x-%04x-%12s',
// 32 bits for "time_low"
substr($hash, 0, 8),
// 16 bits for "time_mid"
substr($hash, 8, 4),
// 16 bits for "time_hi_and_version",
// four most significant bits holds version number 5
(hexdec(substr($hash, 12, 4)) & 0x0fff) | 0x5000,
// 16 bits, 8 bits for "clk_seq_hi_res",
// 8 bits for "clk_seq_low",
// two most significant bits holds zero and one for variant DCE1.1
(hexdec(substr($hash, 16, 4)) & 0x3fff) | 0x8000,
// 48 bits for "node"
substr($hash, 20, 12)
);
}
public static function is_valid($uuid) {
return preg_match('/^\{?[0-9a-f]{8}\-?[0-9a-f]{4}\-?[0-9a-f]{4}\-?'.
'[0-9a-f]{4}\-?[0-9a-f]{12}\}?$/i', $uuid) === 1;
}
}
请勿在涉及安全性的任何环境中使用uniqid()
。在这种情况下使用它是太可预测的了。
答案 1 :(得分:5)
尝试uniqid()http://php.net/manual/en/function.uniqid.php
如果你可以使用pecl,你可以尝试这个模块:http://pecl.php.net/package/uuid
如果您在网络服务器中使用Ubuntu,还有一些内容:http://code.google.com/p/php-uuid/
答案 2 :(得分:1)
代码
$rand_val = md5(uniqid() + mt_rand());
<强>声明强>
理论上存在碰撞的可能性,但不太可能。 uniqid和mt_rand()的组合应该使它不足以满足可能存在的用途。虽然这会产生一个32字符长的字符串。
(建设性评论后编辑)
答案 3 :(得分:1)
使用uniqueid()
string uniqid([string $ prefix =“”[,bool $ more_entropy = false]])
虽然它是独特的,但我不知道为什么你有最低长度要求。
答案 4 :(得分:0)
这将为您创建一个至少20个字符的唯一ID
$id = '';
while(strlen($id) < 20)
{
$id .= uniqid();
}