php生成用户密码的两种方式
在用户系统中,生成用户的密码是很重要的,而简单的密码必然给一些不法用户开了一些门户,这里列出几种常见的密码生成方式
一、md5密码
这种应该算是最常见的密码加密方式了
md5是属于非对称加密中的一种,这种密码方式其实说安全也很安全,而因为哈希碰撞的存在,会导致可能会出现漏洞
最好是在加密的时候,加入混淆字符串,如下所示
二、hash密码
这种加密方式主要使用单向散列算法创建密码的散列
password_default 使用 bcrypt 算法
password_bcrypt 使用 crypt_blowfish 算法创建散列
password_argon2i 使用 argon2 散列算法创建散列
这种密码加密方式数据库里储存结果的列可超过60个字符,所以varchar长度请设置255
ps:php生成随机密码的几种方法
方法一:
1、在 33 - 126 中生成一个随机整数,如 35,
2、将 35 转换成对应的ascii码字符,如 35 对应 #
3、重复以上 1、2 步骤 n 次,连接成 n 位的密码
该算法主要用到了两个函数,mt_rand ( int $min , int $max )函数用于生成随机整数,其中 $min - $max 为 ascii 码的范围,这里取 33 -126 ,可以根据需要调整范围,如ascii码表中 97 - 122 位对应 a - z 的英文字母,具体可参考 ascii码表; chr ( int $ascii )函数用于将对应整数 $ascii 转换成对应的字符。
方法二:
1、预置一个的字符串 $chars ,包括 a - z,a - z,0 - 9,以及一些特殊字符
2、在 $chars 字符串中随机取一个字符
3、重复第二步 n 次,可得长度为 n 的密码
方法三:
1、预置一个的字符数组 $chars ,包括 a - z,a - z,0 - 9,以及一些特殊字符
2、通过array_rand()从数组 $chars 中随机选出 $length 个元素
3、根据已获取的键名数组 $keys,从数组 $chars 取出字符拼接字符串。该方法的缺点是相同的字符不会重复取。
方法四:
本方法是本文被蓝色理想转载后,一名网友提供的一个新方法,算法简单,代码简短,只是因为md5()函数的返回值的缘故,生成的密码只包括字母和数字,不过也算是一个不错的方法。算法思想:
1、time() 获取当前的 unix 时间戳
2、将第一步获取的时间戳进行 md5() 加密
3、将第二步加密的结果,截取 n 位即得想要的密码
到此这篇关于php生成用户密码的两种方式 的文章就介绍到这了,更多相关php生成用户密码内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!