Heim > Artikel > Backend-Entwicklung > Ein Fall der Implementierung relativer Pfade mithilfe des PHP-Algorithmus
Dieser Artikel stellt hauptsächlich relevante Informationen zu Beispielen für die Implementierung relativer Pfade im PHP-Algorithmus vor. Ich hoffe, dass dieser Artikel jedem helfen kann, eine solche Funktion zu realisieren
Beispiel PHP-Algorithmus zur Implementierung des relativen Pfads
Relativen Pfad berechnen (dasselbe Verzeichnis kann ignoriert und durch ../ oder ./ dargestellt werden)
Implementierungscode:
class Relatively{ private function __construct(){ } /** * 算出相对路径(相同的目录可以忽略用../ 或者 ./ 表示) * @param Strint $path1 * @param Strint $path2 * @return string */ public static function relaroot($path1,$path2){ $rearray=array(); $arr1=explode('/', dirname($path1)); $arr2=explode('/', dirname($path2)); for($i=0,$len=count($arr2)-1;$i<$len;$i++){ if($arr1[$i]!=$arr2[$i]){ break; } if($i==1){ $rearray=array(); } if($i!=1 && $i<$len){ $rearray=array_fill(0,$len-$i,'..'); } if($i==$len){ $rearray=array('./'); } } $reroot=array_merge($rearray,array_slice($arr2, $i)); return implode('/', $reroot); } } $path1="a/b/c/d/index.php"; $path2="/a/b/12/34/index1.php"; $a=Relatively::relaroot($path1, $path2); echo $a;
Das obige ist der detaillierte Inhalt vonEin Fall der Implementierung relativer Pfade mithilfe des PHP-Algorithmus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!