您好,欢迎访问一九零五行业门户网

php上传图片重命名的六种方法

复制代码
2,md5:与guid 一样会输出32 字符十六进制数,区别是guid是随机产生的,md5需要根据输入的数据生成。例子:
复制代码
输出结果:8b1a9953c4611296a827abf8c47804d7优点:可以根据输入的种子数据来控制输出的数值,如果种子数据是规律性不重复的,通过md5可以对数据进行保护,产生很大的混淆作用。缺点:32位字符过长;需提供不重复的种子数据;用法:高并发,以秒为种子数据,仍然会出现重复现象。例子:
复制代码
3,uniqid():返回13或23位字符串对于我们目的来说,uniqid()像是md5()的改进版,尤其是我们可以采用差异性标识作为字符串前缀,可以降低重复命名出现的几率。对于非高并发等极端情况,推荐使用此函数,已经可以满足一般性需求。
定义:uniqid() 函数基于以微秒计的当前时间,生成一个唯一的 id。用法:uniqid(prefix,more_entropy)说明:prefix可以为输出的字符串添加前缀,示例如下,more_entropy参数为true时,将输出23位字符串。
例子:
复制代码
输出结果:string(13) 51734aa562254 string(14) a51734aa562257优点:13位字符串长度,是可以接受的文件命名长度;可以添加前缀,结果包含数据混淆,能够避免反推原始数据。缺点:同md5相似,高并发,以秒为种子数据,仍然会出现重复现象。
三、升级版方案:1,fast_uuid:返回17位数字有点像uniqid()的不完全定制版,这个函数里面出现的“种子数开始时间”概念很有启发性。time()和uniqid()中默认用到的时间都是从1970年开始计算的,长度有十位(1366512439),采用“种子数开始时间”能够缩小这个数值。因为,从实际需求来看,仅仅是一个能够自动增长的数值即可。起始时间自定义以后,除了减少长度,还能够起到混淆的作用。
例子:
0) { $id .= substr(sprintf('%010u', mt_rand()), 0, $suffix_len); } return $id;}
复制代码
输出结果:29832412631099013
2,time()+随机数:上例中已出现了随机数的使用,是为了解决一秒下发生的多次请求。提供两个函数:
复制代码
四、最终方案:思路:userid+秒+随机数。其中“userid+秒”10进制转64进制,缩减位数;说明:userid: 64进制最大值“zzzz”转换为十进制等于”16777215“,”zzz“转换为十进制最大值等于”262143“;秒:设置自己的时间起点。
= $len) { return $return; } else { return str_pad($return, $len, '0', str_pad_left); } } return $return; } /**
* 将10进制的数字字符串转为64进制的数字字符串 * @param $m string 10进制的数字字符串 * @param $len integer 返回字符串长度,如果长度不够用0填充,0为不填充 * @return string * @author 野马 */ function hex10to64($m, $len = 0) { $keycode = keycode; $hex2 = decbin($m); $hex2 = str_rsplit($hex2, 6); $hex64 = array(); foreach($hex2 as $one) { $t = bindec($one); $hex64[] = $keycode[$t]; } $return = preg_replace('/^0*/', '', implode('', $hex64)); if($len) { $clen = strlen($return); if($clen >= $len) { return $return; } else { return str_pad($return, $len, '0', str_pad_left); } } return $return; } /**
* 将16进制的数字字符串转为64进制的数字字符串 * @param $m string 16进制的数字字符串 * @param $len integer 返回字符串长度,如果长度不够用0填充,0为不填充 * @return string * @author 野马 */ function hex16to64($m, $len = 0) { $keycode = keycode; $hex2 = array(); for($i = 0, $j = strlen($m); $i $hex2[] = str_pad(base_convert($m[$i], 16, 2), 4, '0', str_pad_left); } $hex2 = implode('', $hex2); $hex2 = str_rsplit($hex2, 6); foreach($hex2 as $one) { $hex64[] = $keycode[bindec($one)]; } $return = preg_replace('/^0*/', '', implode('', $hex64)); if($len) { $clen = strlen($return); if($clen >= $len) { return $return; } else { return str_pad($return, $len, '0', str_pad_left); } } return $return; } /**
* 功能和php原生函数str_split接近,只是从尾部开始计数切割 * @param $str string 需要切割的字符串 * @param $len integer 每段字符串的长度 * @return array * @author 野马 */ function str_rsplit($str, $len = 1) { if($str == null || $str == false || $str == '') return false; $strlen = strlen($str); if($strlen $headlen = $strlen % $len; if($headlen == 0) { return str_split($str, $len); } $return = array(substr($str, 0, $headlen)); return array_merge($return, str_split(substr($str, $headlen), $len)); }$a=idate(u);
echo \r\n
e: . hex10to64($a);echo \r\n
e: . hex64to10(hex10to64($a));
复制代码
算法2:
0, '1' => 1, '2' => 2, '3' => 3, '4' => 4, '5' => 5, '6' => 6, '7' => 7, '8' => 8, '9' => 9, '_' => 10, '$' => 11, 'a' => 12, 'b' => 13, 'c' => 14, 'd' => 15, 'e' => 16, 'f' => 17, 'g' => 18, 'h' => 19, 'i' => 20, 'j' => 21, 'k' => 22, 'l' => 23, 'm' => 24, 'n' => 25, 'o' => 26, 'p' => 27, 'q' => 28, 'r' => 29, 's' => 30, 't' => 31, 'u' => 32, 'v' => 33, 'w' => 34, 'x' => 35, 'y' => 36, 'z' => 37, 'a' => 38, 'b' => 39, 'c' => 40, 'd' => 41, 'e' => 42, 'f' => 43, 'g' => 44, 'h' => 45, 'i' => 46, 'j' => 47, 'k' => 48, 'l' => 49, 'm' => 50, 'n' => 51, 'o' => 52, 'p' => 53, 'q' => 54, 'r' => 55, 's' => 56, 't' => 57, 'u' => 58, 'v' => 59, 'w' => 60, 'x' => 61, 'y' => 62, 'z' => 63, ); $result = 0; $len = strlen($sixty_four); for ($n = 0; $n $result *= 64;
$result += $base_map[$sixty_four{$n}]; } return $result;
}$a=idate(u);
var_dump(dec2s4($a));var_dump(s42dec(dec2s4($a)));
复制代码
算法效率测试:
$strarr = array();
$time1 = microtime(true);for($i = 0; $i $str = idate(u)+$i; $strarr[] = {$i}->$str\r\n
; } $time2 = microtime(true); $time3 = $time2 - $time1; $time1 = microtime(true);
for($i = 0; $i $str = dec2s4(idate(u)+$i); $strarr[] = {$i}->$str\r\n
;}$time2 = microtime(true);echo \r\n
运行10000次用时(秒): . ($time2 - $time1 - $time3);
复制代码
测试结果:算法1:0.1687250137329算法2:0.044965028762817结论:算法1虽然效率上差一些,但是可以把md5生成的16进制转化为64进制,能够使用在必须使用md5的环境下缩短字符串。
六、总结本文内容的关键点是使用10进制转换为64进制来进行字符串的缩减。例如,使用fast_uuid生成的17位数字,转换为64进制仅有7位字符;
以上就是有关php上传图片重命名的全部内容了,希望对大家有所帮助。
其它类似信息

推荐信息