单行PHP随机字符串生成器?

问题描述 投票:38回答:16

我正在寻找生成随机/唯一字符串的最短方法,为此我使用了以下两个:

$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())),"=");

php random
16个回答
29
投票

不是改变字母串,而是获得单个随机字符更快。 从字符串中获取一个随机字符,然后将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 );

2
投票

这实际上取决于您的要求。

我需要字符串在测试运行之间是唯一的,但没有很多其他限制。

我还需要我的字符串从一个角色开始,这对我的目的来说已经足够了。

$mystring = "/a" . microtime(true);

示例输出:

a1511953584.0997


1
投票

基于上面的其他好例子,我正在使用这个来一次生成几十个独特的字符串,而不重复它们:

$string = chr(mt_rand(97, 122))
          . substr(md5(str_shuffle(time() . rand(0, 999999))), 1);

这样,我就能在~5秒内生成1.000.000个独特的字符串。我知道,这并不是那么快,但是因为我只需要一把它们,我很好。顺便说一下,生成10个字符串的时间少于0.0001 ms。


1
投票

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);

参考网址:Generate random String using PHP


1
投票

此函数返回随机小写字符串:

function randomstring($len=10){
 $randstr='';
 for($iii=1; $iii<=$len; $iii++){$randstr.=chr(rand(97,122));};
 return($randstr);
};

1
投票

我发现base64编码对于创建随机字符串非常有用,并使用以下行:

base64_encode(openssl_random_pseudo_bytes(9));

它给了我一个随机字符串的12个位置,其余的好处是随机性是“密码强”。


1
投票

生成字符串由随机字符组成,您可以使用此功能

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;
}

1
投票

如何以糟糕的方式匹配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, '.')));

26
投票

我找到了这样的东西:

$length = 10;
$randomString = substr(str_shuffle(md5(time())),0,$length);
echo $randomString;

6
投票

如果您需要以字母开头,您可以这样做。这很麻烦......但它是一条线。

$randomString = substr(str_shuffle("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 1) . substr(str_shuffle("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 10);

echo $randomString;

6
投票

我认为这个问题需要更好的答案。像代码高尔夫!这也使用更好的随机字节发生器。

preg_replace("/[\/=+]/", "", base64_encode(openssl_random_pseudo_bytes(8)));

显然,增加更长密码的字节数。


4
投票

base_convert(microtime(true), 10, 36);


4
投票

创建一个200字符长的hexdec字符串:

$string = bin2hex(openssl_random_pseudo_bytes(100));

maaarghk's answer虽然更好。


3
投票

我已经为你生成了这段代码。简单,简洁,(合理)优雅。

如前所述,如果长度对您不重要,则使用base64 - 但是它使用str_replace删除“==”。

<?php
        echo  str_ireplace("==", "", base64_encode(time()));
?>

3
投票

你可以试试这个:

 function KeyGenerator($uid) {
    $tmp = '';
    for($z=0;$z<5;$z++) {
      $tmp .= chr(rand(97,122)) . rand(0,100);
    }
    $tmp .= $uid;
    return $tmp;
  }

2
投票

我用这个功能

用法:

 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;
  }
© www.soinside.com 2019 - 2024. All rights reserved.