在剛剛寫的一篇博文《為網站添加圖片網站地圖》中我提到有三種辦法來實現:
- 專門寫的php程序,與.htaccess的rewrite配合重寫網址(詳見《Drupal網站Views生成頁面的XML網站地圖構建》)
- 用module文件中的menu路徑來生成(現在寫的這篇博客文章來介紹)
- 用views中的xml views來生成(這個辦法我也再專門寫一篇博客文章來介紹)
其實用module文件中menu路徑來生成網址是Drupal的标準做法,我們用這種做法生成過普通html頁面以及png圖片頁面,最近還用這個辦法生成過svg圖片文件,隻要在調用的函數中使用header控制生成頁面的格式就可以。
下面是module文件中生成image-sitemap.xml的例子:
/** * menu定義 * 并不是網頁中的菜單定義,而是路由定義、路徑定義,在module中定義新的頁面時使用 */ function emoji_menu() { $items = array(); ... //image sitemap $items['image-sitemap.xml'] = array ( 'title' => 'Image Sitemap', 'page callback' => 'image_sitemap_xml', 'access callback' => 'user_access', 'access arguments' => array('access content'), ); ... } /** * 函數:圖片站點地圖 * @param: 無 * @return: 圖片站點地圖xml代碼 */ function image_sitemap_xml() { global $language; $language_code = $language->language; $server_name = $_SERVER['SERVER_NAME']; $start = '<?xml version="1.0" encoding="UTF-8"?> <?xml-stylesheet type="text/xsl" href="https://'.$server_name.'/xml-image-sitemap.xsl"?> <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:image="http://www.google.com/schemas/sitemap-image/1.1"> '; $end = '</urlset>'; $output = $start; $emoji_array = array(元素略...); foreach ($emoji_array as $key => $emoji) { $emoji_url = urlencode($emoji); $short_name = ...; $code_point = ...; $output .= "<url>\n"; $output .= " <loc>https://www.emojiall.com/$language_code/emoji/$emoji_url</loc>\n"; //社交媒體分享圖片 $output .= " <image:image>\n"; $output .= " <image:loc>https://www.emojiall.com/social-media-share/$emoji_url.png</image:loc>\n"; $output .= " <image:title>$emoji - emojiall.com</image:title>\n"; $output .= " <image:caption>$short_name</image:caption>\n"; $output .= " </image:image>\n"; //頭部svg圖片 $output .= " <image:image>\n"; $output .= " <image:loc>https://www.emojiall.com/en/header-svg/$emoji_url.svg</image:loc>\n"; $output .= " <image:title>$emoji $short_name SVG - emojiall.com</image:title>\n"; $output .= " <image:caption>$short_name $code_point</image:caption>\n"; $output .= " </image:image>\n"; $output .= "</url>\n"; } $output .= $end; header("Content-type: application/xml"); print $output; return NULL; }
上面的代碼中略去了少量具體值,不影響實質。
這樣就在一個Drupal 7網站中生成了一個可以訪問的圖片網站地圖。
评论1
感謝博主分享
感謝博主分享