

新闻资讯
技术百科最稳妥的方法是用 pathinfo() 拆解路径再拼接:$info = pathinfo($path); $new_path = $info['dirname'] . '/' . $new_basename . '.' . $info['extension'];
直接用 dirname() + basename() 拼接最稳妥,避免手动字符串切割出错。尤其当路径含多层 /、末尾有斜杠、或含查询参数时,正则或 str_replace() 极易误伤。
basename($path) 提取原始文件名(含扩展名),dirname($path) 提取目录部分,二者拼接可完全隔离变更范围/(如 /var/www/),basename() 会返回空字符串,需先用 rtrim($path, '/') 防御str_replace('old.jpg', 'new.png', $path) —— 若目录名里也含 old.jpg(比如 /old.jpg/assets/),就会错替用 pathinfo() 拆解最清晰,它能明确分离目录、文件名(不含扩展)、扩展名三部分,比手动 strrpos() 找点更可靠。
$path = '/home/user/report_v1.pdf'; $info = pathinfo($path); $new_basename = 'report_final'; $new_path = $info['dirname'] . '/' . $new_basename . '.' . $info['extension']; // 结果:/home/user/report_final.pdf
$info['extension'] 自动带点(如 .pdf),拼接时不用额外加 .
/tmp/README),$info['extension'] 为空字符串,结果自然不带点 —— 行为符合直觉pathinfo() 默认按最后一个点拆分,所以 archive.tar.gz 的 extension 是 gz,不是 tar.gz
用 array_map() + 匿名函数封装替换逻辑,比写 for 循环更简洁,也方便复用。
$paths = [
'/img/photo.jpg',
'/docs/manual.pdf',
'/log/2025-01-01.log'
];
$replace_fn = function($path, $new_name) {
$info = pathinfo($path);
return $info['dirname'] . '/' . $new_name . '.' . $info['extension'];
};
$new_paths = array_map(function($p) use ($replace_fn) {
return $replace_fn($p, 'backup_' . basename($p, '.' . pathinfo($p, PATHINFO_EXTENSION)));
}, $paths);
// 结果:['/img/backup_photo.jpg', '/docs/backup_manual.pdf', ...]
use ($replace_fn) 是为了在内层匿名函数里调用外层逻辑,避免重复写解析代码basename($p, '.' . pathinfo($p, PATHINFO_EXTENSION)) 是安全去扩展名的写法,比 substr($p, 0, strrpos($p, '.')) 少一步判断点是否存在./file.txt)或 Windows 风格(C:\tmp\test.php),pathinfo() 仍能正确处理,无需额外适配先用 parse_url() 拆出 path 部分,替换后再拼回去。千万别直接在完整 URL 上操作,否则可能把 ?v=old.jpg 里的 old.jpg 也替掉。
$url = 'https://example.com/assets/icon.svg?v=2&ts=1712345678'; $parsed = parse_url($url); $path_info = pathinfo($parsed['path']); $new_path = $path_info['dirname'] . '/logo.png'; $new_url = $parsed['scheme'] . '://' . $parsed['host'] . $new_path . (!empty($parsed['query']) ? '?' . $parsed['query'] :''); // 结果:https://example.com/assets/logo.png?v=2&ts=1712345678
parse_url() 对复杂 URL(含用户信息、端口、锚点)也健壮,比正则靠谱得多$parsed['path'] 可能为空(如 https://example.com/?q=test),此时要判空再调 pathinfo()
%20)。只要坚持先拆解(pathinfo / parse_url)再组装,就能绕过 90% 的坑。