千家信息网

php如何上传图片并修改名字

发表于:2025-11-20 作者:千家信息网编辑
千家信息网最后更新 2025年11月20日,这篇文章主要为大家展示了"php如何上传图片并修改名字",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"php如何上传图片并修改名字"这篇文章吧。php上传图
千家信息网最后更新 2025年11月20日php如何上传图片并修改名字

这篇文章主要为大家展示了"php如何上传图片并修改名字",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"php如何上传图片并修改名字"这篇文章吧。

php上传图片并修改名字的方法:1、通过GUID方法给上传的图片重命名;2、使用MD5方法;3、使用uniqid方法;4、使用fast_uuid方法等等。

本文操作环境:Windows7系统、PHP7.1版,Dell G3电脑

php怎么上传图片并修改名字?

6种php上传图片重命名的方法实例

一、适用场景:
无法使用从数据库中返回的自增长数字,给上传图片重命名。
这是图片或文件上传的流程决定的。
一般图片上传处理过程是,先上传图片到服务器,重命名之后,插入到数据库。
也就是说,在数据库中非常容易获得的自增长id,无法用于给上传的图片重命名,来避免文件名称的重复,
而采用从数据库中获取最大id加1的方式,增加了数据库连接的次数,不适用于高并发和数据量巨大的情况;
二、常规方案:
1,guid:32 字符十六进制数。
格式:GUID 的格式为"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",其中每个 x 是 0-9 或 a-f 范围内的一个32位十六进制数。例如:6F9619FF-8B86-D011-B42D-00C04FC964FF 即为有效的 GUID 值。
优点:几乎不会重复;
缺点:对于给上传的图片重命名,还是过长了。
用法:

代码如下:

/*    com_create_guid()是php5版本支持的功能,对于不支持的版本,可以自己进行定义;*/function guid(){   if (function_exists('com_create_guid')){       return com_create_guid();   }else{       mt_srand((double)microtime()*10000);//optional for php 4.2.0 and up.       echo(mt_rand());       $charid = strtoupper(md5(uniqid(rand(), true)));       $hyphen = chr(45);// "-"       $uuid = chr(123)// "{"               .substr($charid, 0, 8).$hyphen               .substr($charid, 8, 4).$hyphen               .substr($charid,12, 4).$hyphen               .substr($charid,16, 4).$hyphen               .substr($charid,20,12)               .chr(125);// "}"       return $uuid;   }}


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),采用"种子数开始时间"能够缩小这个数值,因为我们实际上需要的,仅仅是一个能够自动增长的数值即可。
起始时间自定义以后,除了减少长度,还能够起到混淆的作用。

代码如下:

/** 参数 suffix_len指定 生成的 ID 值附加多少位随机数,默认值为 3。* 感谢"Ivan Tan|谭俊青 DrinChing (at) Gmail.com"提供的算法。* @param int suffix_len* @return string*/function fast_uuid($suffix_len=3){    //! 计算种子数的开始时间    $being_timestamp = strtotime('2013-3-21');    $time = explode(' ', microtime());    $id = ($time[1] - $being_timestamp) . sprintf('u', substr($time[0], 2, 6));    if ($suffix_len > 0)    {        $id .= substr(sprintf('0u', mt_rand()), 0, $suffix_len);    }    return $id;}

输出,

29832412631099013

2,time()+随机数:
上例中已经出现了随机数的使用,是为了解决一秒下发生的多次请求。提供两个函数如下,

代码如下:

四、最终方案
思路:userid+秒+随机数。其中"userid+秒"10进制转64进制,缩减位数;
说明:
userid: 64进制最大值"ZZZZ"转换为十进制等于"16777215","ZZZ"转换为十进制最大值等于"262143";
秒:设置自己的时间起点。
$less=time()-strtotime('2012-4-21′); 转换为64进制"1SpRe",5位
$less=time()-strtotime('2013-3-21′); 转换为64进制"_jHY";4位
随机数:使用random(3)生成3位随机数;
最终结果:
4位userid+4位秒+3位随机数=11位字符串。虽然与uniqid()结果看上去相似,但是强壮度有所提高。
五、十进制转64进制算法:
算法1:

代码如下:

const KeyCode = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_$';    /**     * 将64进制的数字字符串转为10进制的数字字符串     * @param $m string 64进制的数字字符串     * @param $len integer 返回字符串长度,如果长度不够用0填充,0为不填充     * @return string     * @author 野马     */    function hex64to10($m, $len = 0) {        $m = (string)$m;        $hex2 = '';        $Code = KeyCode;        for($i = 0, $l = strlen($Code); $i < $l; $i++) {            $KeyCode[] = $Code[$i];        }        $KeyCode = array_flip($KeyCode);        for($i = 0, $l = strlen($m); $i < $l; $i++) {            $one = $m[$i];            $hex2 .= str_pad(decbin($KeyCode[$one]), 6, '0', STR_PAD_LEFT);        }        $return = bindec($hex2);        if($len) {            $clen = strlen($return);            if($clen >= $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 < $j; ++$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 <= $len) return array($str);        $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:

代码如下:

function dec2s4($dec) {    $base = '0123456789_$abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';    $result = '';    do {        $result = $base[$dec % 64] . $result;        $dec = intval($dec / 64);    } while ($dec != 0);    return $result;}function  s42dec($sixty_four) {    $base_map = array ( '0' => 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 < $len; $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 < 10000; ++$i) {     $str = idate("U")+$i;     $strarr[] = "{$i}->$str\r\n
"; } $time2 = microtime(true); $time3 = $time2 - $time1; $time1 = microtime(true); for($i = 0; $i < 10000; ++$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的环境下缩短字符串。

以上是"php如何上传图片并修改名字"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

字符 字符串 进制 数据 图片 数字 长度 代码 种子 算法 时间 随机数 输出 方法 名字 函数 数据库 结果 生成 野马 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 双阳区现代化网络安全质量服务 不懂网络技术怎么开网络公司 计算机网络技术与生活 服务器怎么确定做了磁盘阵列 广州专业软件开发正规平台 人人字幕软件开发 网络安全画超简单获奖 陕西卫视网络安全特别晚会 世界上网络安全的公司 plsql数据库时间配置 河南新华互联网科技学校 河南速点网络技术 ios访问服务器异常 网络安全工程师用的什么手机 app软件开发手机培训学习 云代账互联网科技公司 魔兽赛季服骨镰服务器什么时候开 四川智慧党建软件开发公司 数据库查找方法 操作系统与数据库系统 16年国家网络安全战略 英灵神殿进入别人服务器 access数据库查询用途 软件开发部长职责 怎么看服务器上数据库类型 台州网络安全准入控制供应商 蒙西电网公司网络安全装置名录 网络安全三同步选择 如何修改代理服务器 网上商城数据库设计目录
0