Méthode php pour calculer le chemin relatif entre deux fichiers
Par exemple :
fichier Le chemin du fichier A est /home/web/lib/img/cache.php
Le chemin du fichier B est /home/web/ api/img /show.php
Ensuite, le chemin du fichier A par rapport au fichier B est ../../lib/img/cache.php , c'est-à-dire que le fichier B accède au chemin relatif du fichier A.
fonction getRelativePath
<?php /** 计算path1 相对于 path2 的路径,即在path2引用paht1的相对路径 * @param String $path1 * @param String $path2 * @return String */ function getRelativePath($path1, $path2){ $arr1 = explode('/', $path1); $arr2 = explode('/', $path2); // 获取相同路径的部分 $intersection = array_intersect_assoc($arr1, $arr2); $depth = 0; for($i=0,$len=count($intersection); $i<$len; $i++){ $depth = $i; if(!isset($intersection[$i])){ break; } } // 前面全部匹配 if($i==count($intersection)){ $depth ++; } // 将path2的/ 转为 ../,path1获取后面的部分,然后合拼 // 计算前缀 if(count($arr2)-$depth-1>0){ $prefix = array_fill(0, count($arr2)-$depth-1, '..'); }else{ $prefix = array('.'); } $tmp = array_merge($prefix, array_slice($arr1, $depth)); $relativePath = implode('/', $tmp); return $relativePath; } ?>
démo
<?php $path1 = '/home/web/lib/img/cache.php'; $path2 = '/home/show.php'; echo getRelativePath($path1, $path2).'<br>'; // ./web/lib/img/cache.php $path1 = '/home/web/lib/img/cache.php'; $path2 = '/home/web/api/show.php'; echo getRelativePath($path1, $path2).'<br>'; // ../lib/img/cache.php $path1 = '/home/web/lib/img/cache.php'; $path2 = '/home/web/api/img/show.php'; echo getRelativePath($path1, $path2).'<br>'; // ../../lib/img/cache.php $path1 = '/home/web/lib/img/cache.php'; $path2 = '/xhome/web/show.php'; echo getRelativePath($path1, $path2).'<br>'; // ../../home/web/lib/img/cache.php ?>
Cet article explique comment calculer deux Relatives méthode de chemin entre les fichiers, veuillez faire attention au site Web chinois php pour plus de contenu connexe.
Recommandations associées :
Expliquez comment PHP obtient la date spécifiée
Explication détaillée de la façon dont PHP génère une classe RequestID unique
Comment vérifier la capacité des tables de base de données via MySQL
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!