我正在寻找生成随机/唯一字符串的最短方法,为此我使用了以下两个:
$cClass = sha1(time());
要么
$cClass = md5(time());
但是,我需要字符串以字母字符开头,我正在查看base64编码,但最后添加==
然后我需要摆脱它。
用一行代码实现这一目标的最佳方法是什么?
更新:
PRNDL提出了一个很好的建议,我最终使用它,但有点修改
echo substr(str_shuffle(abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ),0, 1) . substr(str_shuffle(aBcEeFgHiJkLmNoPqRstUvWxYz0123456789),0, 31)
将产生32个字符来模仿md5哈希,但它总是会产生第一个字母字母,就像这样;
然而,Uours真的改进了他的答案;
substr(str_shuffle("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 1).substr(md5(time()),1);
更短,更甜
Anonymous2011的另一个建议非常棒,但由于某种原因,第一个角色总是要么M,N,Y,Z所以不适合我的目的但是会选择答案,顺便说一下有谁知道为什么它会总是产生那些特定的字母?
这是我修改版本的预览
echo rtrim(base64_encode(md5(microtime())),"=");
不是改变字母串,而是获得单个随机字符更快。
从字符串中获取一个随机字符,然后将md5( time( ) )
附加到它。在附加md5( time( ) )
之前,从中删除一个字符,以便将结果字符串长度保持为32个字符:
substr("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ", mt_rand(0, 51), 1).substr(md5(time()), 1);
小写版本:
substr("abcdefghijklmnopqrstuvwxyz", mt_rand(0, 25), 1).substr(md5(time()), 1);
或者甚至更短,更小一点的小写版本:
chr(mt_rand(97, 122)).substr(md5(time()), 1);
/* or */
chr(mt_rand(ord('a'), ord('z'))).substr(md5(time()), 1);
任何试图在一秒内生成许多随机字符串的人的注释:
由于time( )
以秒为单位返回时间,因此md5( time( ) )
在给定的秒数内将是相同的,因为如果在一秒钟内生成许多随机字符串,那些可能最终会产生一些重复。
我已经使用以下代码进行了测试这测试小写版本:
$num_of_tests = 100000;
$correct = $incorrect = 0;
for( $i = 0; $i < $num_of_tests; $i++ )
{
$rand_str = substr( "abcdefghijklmnopqrstuvwxyz" ,mt_rand( 0 ,25 ) ,1 ) .substr( md5( time( ) ) ,1 );
$first_char_of_rand_str = substr( $rand_str ,0 ,1 );
if( ord( $first_char_of_rand_str ) < ord( 'a' ) or ord( $first_char_of_rand_str ) > ord( 'z' ) )
{
$incorrect++;
echo $rand_str ,'<br>';
}
else
{
$correct++;
}
}
echo 'Correct: ' ,$correct ,' . Incorrect: ' ,$incorrect ,' . Total: ' ,( $correct + $incorrect );
这实际上取决于您的要求。
我需要字符串在测试运行之间是唯一的,但没有很多其他限制。
我还需要我的字符串从一个角色开始,这对我的目的来说已经足够了。
$mystring = "/a" . microtime(true);
示例输出:
a1511953584.0997
基于上面的其他好例子,我正在使用这个来一次生成几十个独特的字符串,而不重复它们:
$string = chr(mt_rand(97, 122))
. substr(md5(str_shuffle(time() . rand(0, 999999))), 1);
这样,我就能在~5秒内生成1.000.000个独特的字符串。我知道,这并不是那么快,但是因为我只需要一把它们,我很好。顺便说一下,生成10个字符串的时间少于0.0001 ms。
JavaScript解决方案:
function randomString(pIntLenght) {
var strChars = “0123456789ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz”;
var strRandomstring = ”;
for (var intCounterForLoop=0; intCounterForLoop < pIntLenght; intCounterForLoop++) {
var rnum = Math.floor(Math.random() * strChars.length);
strRandomstring += strChars.substring(rnum,rnum+1);
}
return strRandomstring;
}
alert(randomString(20));
参考网址:Generate random string using JavaScript
PHP解决方案:
function getRandomString($pIntLength = 30) {
$strAlphaNumericString = ’0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ’;
$strReturnString = ”;
for ($intCounter = 0; $intCounter < $pIntLength; $intCounter++) {
$strReturnString .= $strAlphaNumericString[rand(0, strlen($strAlphaNumericString) - 1)];
}
return $strReturnString;
}
echo getRandomString(20);
此函数返回随机小写字符串:
function randomstring($len=10){
$randstr='';
for($iii=1; $iii<=$len; $iii++){$randstr.=chr(rand(97,122));};
return($randstr);
};
我发现base64编码对于创建随机字符串非常有用,并使用以下行:
base64_encode(openssl_random_pseudo_bytes(9));
它给了我一个随机字符串的12个位置,其余的好处是随机性是“密码强”。
生成字符串由随机字符组成,您可以使用此功能
public function generate_random_name_for_file($length=50){
$key = '';
$keys = array_merge(range(0, 9), range('a', 'z'));
for ($i = 0; $i < $length; $i++) {
$key .= $keys[array_rand($keys)];
}
return $key;
}
如何以糟糕的方式匹配OP原始请求(为了可读性而扩展):
// [0-9] ASCII DEC 48-57
// [A-Z] ASCII DEC 65-90
// [a-z] ASCII DEC 97-122
// Generate: [A-Za-z][0-9A-Za-z]
$r = implode("", array_merge(array_map(function($a)
{
$a = [rand(65, 90), rand(97, 122)];
return chr($a[array_rand($a)]);
}, array_fill(0, 1, '.')),
array_map(function($a)
{
$a = [rand(48, 57), rand(65, 90), rand(97, 122)];
return chr($a[array_rand($a)]);
}, array_fill(0, 7, '.'))));
最后一个array_fill()会将'7'改为你的长度 - 1。
对于那个完成所有alpha-nurmeric(并且仍然很慢)的人:
// [0-9A-Za-z]
$x = implode("", array_map(function($a)
{
$a = [rand(48, 57), rand(65, 90), rand(97, 122)];
return chr($a[array_rand($a)]);
}, array_fill(0, 8, '.')));
我找到了这样的东西:
$length = 10;
$randomString = substr(str_shuffle(md5(time())),0,$length);
echo $randomString;
如果您需要以字母开头,您可以这样做。这很麻烦......但它是一条线。
$randomString = substr(str_shuffle("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 1) . substr(str_shuffle("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 10);
echo $randomString;
我认为这个问题需要更好的答案。像代码高尔夫!这也使用更好的随机字节发生器。
preg_replace("/[\/=+]/", "", base64_encode(openssl_random_pseudo_bytes(8)));
显然,增加更长密码的字节数。
base_convert(microtime(true), 10, 36);
我已经为你生成了这段代码。简单,简洁,(合理)优雅。
如前所述,如果长度对您不重要,则使用base64 - 但是它使用str_replace删除“==”。
<?php
echo str_ireplace("==", "", base64_encode(time()));
?>
你可以试试这个:
function KeyGenerator($uid) {
$tmp = '';
for($z=0;$z<5;$z++) {
$tmp .= chr(rand(97,122)) . rand(0,100);
}
$tmp .= $uid;
return $tmp;
}
我用这个功能
用法:
echo randomString(20, TRUE, TRUE, FALSE);
/**
* Generate Random String
* @param Int Length of string(50)
* @param Bool Upper Case(True,False)
* @param Bool Numbers(True,False)
* @param Bool Special Chars(True,False)
* @return String Random String
*/
function randomString($length, $uc, $n, $sc) {
$rstr='';
$source = 'abcdefghijklmnopqrstuvwxyz';
if ($uc)
$source .= 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
if ($n)
$source .= '1234567890';
if ($sc)
$source .= '|@#~$%()=^*+[]{}-_';
if ($length > 0) {
$rstr = "";
$length1= $length-1;
$input=array('a','b','c','d','e','f','g','h','i','j,''k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z')
$rand = array_rand($input, 1)
$source = str_split($source, 1);
for ($i = 1; $i <= $length1; $i++) {
$num = mt_rand(1, count($source));
$rstr1 .= $source[$num - 1];
$rstr = "{$rand}{$rstr1}";
}
}
return $rstr;
}