|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
应该大致熟悉了一些学习过程,也许我的过程和你的有些出路,但是不管怎么样是殊途同归,我写这么多,也只是给大家一个借鉴的机会,至于好与不好,默默不敢打包票^0^利用PHP开辟使用程序,特别是网站程序,经常必要天生随秘密码,如用户注册天生随秘密码,用户重置暗码也必要天生一个随机的暗码。随秘密码也就是一串流动长度的字符串,这里我搜集收拾了几种天生随机字符串的办法,以供人人参考。
办法一:
1、在33C126中天生一个随机整数,如35,
2、将35转换成对应的ASCII码字符,如35对应#
3、反复以上1、2步骤n次,毗连成n位的暗码
该算法次要用到了两个函数,mt_rand(int$min,int$max)函数用于天生随机整数,个中$minC$max为ASCII码的局限,这里取33-126,能够依据必要调剂局限,如ASCII码表中97C122位对应aCz的英笔墨母,详细可参考ASCII码表;chr(int$ascii)函数用于将对应整数$ascii转换成对应的字符,详细的函数代码以下:- functioncreate_password($pw_length=8){$randpwd=;for($i=0;$i<$pw_length;$i++){$randpwd.=chr(mt_rand(33,126));}return$randpwd;}
复制代码 利用办法以下,这里天生一个长度为6的随秘密码:办法二:
1、预置一个的字符串$chars,包含aCz,ACZ,0C9,和一些特别字符
2、在$chars字符串中随机取一个字符
3、反复第二步n次,可得长度为n的暗码- functiongenerate_password($length=8){//暗码字符集,可恣意增加你必要的字符$chars=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_[]{}~`+=,.;:/?;$password=;for($i=0;$i<$length;$i++){//这里供应两种字符猎取体例//第一种是利用substr截取$chars中的恣意一名字符;//第二种是取字符数组$chars的恣意元素//$password.=substr($chars,mt_rand(0,strlen($chars)-1),1);$password.=$chars[mt_rand(0,strlen($chars)-1)];}return$password;}
复制代码 办法三:
1、预置一个的字符数组$chars,包含aCz,ACZ,0C9,和一些特别字符
2、经由过程array_rand()从数组$chars中随机选出$length个元素
3、依据已猎取的键名数组$keys,从数组$chars掏出字符拼接字符串。该办法的弱点是不异的字符不会反复取。- functionmake_password($length=8){//暗码字符集,可恣意增加你必要的字符$chars=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,!,@,#,$,%,^,&,*,(,),-,_,[,],{,},<,>,~,`,+,=,,,.,;,:,/,?,);//在$chars中随机取$length个数组元素键名$keys=array_rand($chars,$length);$password=;for($i=0;$i<$length;$i++){//将$length个数组元素毗连成字符串$password.=$chars[$keys[$i]];}return$password;}
复制代码 办法四:
1、time()猎取以后的Unix工夫戳
2、将第一步猎取的工夫戳举行md5()加密
3、将第二步加密的了局,截取n位即得想要的暗码- functionget_password($length=8){$str=substr(md5(time()),0,6);return$str;}
复制代码 工夫效力对照
我们利用以下PHP代码,盘算下面的4个随秘密码天生函数天生6位暗码的运转工夫,进而对他们的工夫效力举行一个复杂的对照。- <?phpfunctiongetmicrotime(){list($usec,$sec)=explode("",microtime());return((float)$usec+(float)$sec);}//纪录入手下手工夫$time_start=getmicrotime();//这里放要实行的PHP代码,如://echocreate_password(6);//纪录停止工夫$time_end=getmicrotime();$time=$time_end-$time_start;//输入运转总工夫echo"实行工夫$timeseconds";?>
复制代码 关于以上测试程序运转工夫的办法,也可参照本站文章:
PHP盘算程序运转工夫的类
终极得出的了局是:
办法一:9.8943710327148E-5秒
办法二:9.6797943115234E-5秒
办法三:0.00017499923706055秒
办法四:3.4093856811523E-5秒
综上能够看出办法一和办法二的实行工夫都差未几,办法四运转工夫最短,而办法三的运转工夫略微长点。
exit来实现结束后面的PHP语句的执行,缩小调试范围,特别是数据库交互的程序,先输出个SQL语句看看,对了,再分析怎么会插入/删除不成功呢?这样对查错很有帮助。 |
|