php 包含字母随机数_php生成随机数 生成随机字符串的5种方法

有时候我们的项目需要生成随机数,但是又不想那么麻烦,那么我们可以使用下面这5种方法生成。

第一种:mt_rand()

function GetRandStr($length){

//字符组合

$str = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';

$len = strlen($str)-1;

$randstr = '';

for ($i=0;$i

$num=mt_rand(0,$len);

$randstr .= $str[$num];

}

return $randstr;

}

//传入长度

$number = GetRandStr(6);

echo $number;

?>

第二种:array_rand()数组

function make_password($length)

{

// 密码字符集,可任意添加你需要的字符

$str = 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', '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',

'0', '1', '2', '3', '4', '5', '6', '7', '8', '9');

// 在 $str 中随机取 $length 个数组元素键名

$keys = array_rand($str, $length);

$password = '';

for($i = 0; $i < $length; $i++)

{

// 将 $length 个数组元素连接成字符串

$password .= $str[$keys[$i]];

}

return $password;

}

echo make_password(6);

?>

第三种:把字符串打乱,然后返回其中的一小截

function getrandstr($length){

$str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890';

$randStr = str_shuffle($str);//打乱字符串

$rands= substr($randStr,0,$length);//substr(string,start,length);返回字符串的一部分

return $rands;

}

echo getrandstr(6);

?>

第四种:返回任意随机数

//返回1000-9999其中的一个随机数

echo rand(1000,9999);

?>

第五种:对时间戳进行MD5加密,截取其中一部分

function token($length){

$str = md5(time());

$token = substr($str,5,$length);

return $token;

}

echo token(6);

?>

5种方法,任你选择,当然还有很多方法,例如多个字符串进行拼接,最后做md5加密或SHA1加密,然后返回字符串,这种比较普遍用于token验证或签名验证。

Author:TANKING

Date:202-05-22

Web:https://www.likeyunba.com/

WeChat:face6009

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值