我有一个人们发布故事的网站,我希望每个故事标题的一部分都包含在指向故事的网址中。
例如,如果海报发布了一个标题为“这是一个示例帖子”的故事,我正在寻找一种方法将其翻译为“这是一个例子的帖子”。
此外,由于标题将在URL中使用,我需要过滤掉所有保留或潜在危险的字符。
是否已经有了这样的方法(功能库无论如何),或者我必须自己编写?
答案 0 :(得分:0)
制作友好网址的小PHP功能。
public function friendly_url($string) {
$table = array(
'Š' => 'S', 'š' => 's',
'Ŀ' => 'Dj',
'đ' => 'dj',
'Ž' => 'Z',
'ž' => 'z',
'Č' => 'C',
'Ŀ' => 'c',
'Ć' => 'C',
'ć' => 'c',
'À' => 'A',
'ÿ' => 'A',
'Â' => 'A',
'Ã' => 'A',
'Ä' => 'A',
'Å' => 'A',
'Æ' => 'A',
'Ç' => 'C',
'È' => 'E',
'É' => 'E',
'Ê' => 'E',
'Ë' => 'E',
'Ì' => 'I',
'ÿ' => 'I',
'Î' => 'I',
'ÿ' => 'I',
'Ñ' => 'N',
'Ò' => 'O',
'Ó' => 'O',
'Ô' => 'O',
'Õ' => 'O',
'Ö' => 'O',
'Ø' => 'O',
'Ù' => 'U',
'Ú' => 'U',
'Û' => 'U',
'Ü' => 'U',
'ÿ' => 'Y',
'Þ' => 'B',
'ß' => 'Ss',
'à' => 'a',
'á' => 'a',
'â' => 'a',
'ã' => 'a',
'ä' => 'a',
'å' => 'a',
'æ' => 'a',
'ç' => 'c',
'è' => 'e',
'é' => 'e',
'ê' => 'e',
'ë' => 'e',
'ì' => 'i',
'í' => 'i',
'î' => 'i',
'ï' => 'i',
'ð' => 'o',
'ñ' => 'n',
'ò' => 'o',
'ó' => 'o',
'ô' => 'o',
'õ' => 'o',
'ö' => 'o',
'ø' => 'o',
'ù' => 'u',
'ú' => 'u',
'û' => 'u',
'ý' => 'y',
'ý' => 'y',
'þ' => 'b',
'ÿ' => 'y',
'Ŕ' => 'R',
'ŕ' => 'r',
' ' => '-'
);
$string = strtr($string, $table);
$string = strtolower($string);
$string = preg_replace("/[^a-zA-Z0-9_.-]/", "", $string);
return $string;
}
答案 1 :(得分:0)
为什么不尝试这样的事情:
$title = "this is an example post";
$url = str_replace(' ', '-', $title);
然后查看PHP手册的urlencode部分,了解评论中的许多示例。
答案 2 :(得分:0)
我刚刚找到this question,就类似主题而言。
第一个答案中给出的功能足以将所有非网友友好字符翻译为' - '。
然后我使用了像奥斯瓦尔多在他的回答中建议的数组,并将我想要的字符(希腊语)翻译成英语。
最终产品是:
function titleToUrlFriendlyTitle($string){
$table = array('Α'=>'a','Ά'=>'a','ά'=>'a', 'α'=>'a', 'Β'=>'b', 'β'=>'b', 'γ'=>'g', 'Γ'=>'g', 'Δ'=>'d', 'δ'=>'d', 'έ'=>'e', 'ε'=>'e', 'Ε'=>'e', 'Έ'=>'e', 'ζ'=>'z', 'Ζ'=>'z', 'η'=>'i', 'Η'=>'i', 'ή'=>'i', 'Ή'=>'i', 'θ'=>'th', 'Θ'=>'th', 'ι'=>'i', 'Ι'=>'i', 'ί'=>'i', 'Ί'=>'i', 'ϊ'=>'i', 'Ϊ'=>'i', 'ΐ'=>'i', 'κ'=>'k', 'Κ'=>'k', 'λ'=>'l', 'Λ'=>'l', 'μ'=>'m', 'Μ'=>'m', 'ν'=>'n', 'Ν'=>'n', 'ξ'=>'ks', 'Ξ'=>'ks', 'ο'=>'o', 'Ο'=>'o', 'Ό'=>'o', 'ό'=>'o', 'π'=>'p', 'Π'=>'p', 'ρ'=>'r', 'Ρ'=>'r', 'σ'=>'s', 'Σ'=>'s', 'τ'=>'t', 'Τ'=>'t', 'Υ'=>'u', 'υ'=>'u', 'Ύ'=>'u', 'ύ'=>'u', 'ϋ'=>'u', 'Ϋ'=>'u', 'ΰ'=>'u', 'φ'=>'f', 'Φ'=>'f', 'χ'=>'x', 'Χ'=>'x', 'Ψ'=>'ps', 'ψ'=>'ps', 'ω'=>'o', 'Ω'=>'o', 'ώ'=>'o', 'Ώ'=>'o');
$string = strtr( $string , $table );
return strtolower(trim(preg_replace('~[^0-9a-z]+~i', '-', html_entity_decode(preg_replace('~&([a-z]{1,2})(?:acute|cedil|circ|grave|lig|orn|ring|slash|th|tilde|uml);~i', '$1', htmlentities($string, ENT_QUOTES, 'UTF-8')), ENT_QUOTES, 'UTF-8')), '-'));
}