拙著「WordPress Web開発逆引きレシピ」が発売されました。
WordPressの様々なカスタマイズについて、逆引きの形式で取り上げています。
PHP 7.0での動作確認も行っています。
Movable Type 4.2以降でRSS 2.0のフィードを配信する
Movable Type 4.2以降では、RSS 2.0のテンプレートが廃止されています。
ただ、場合によっては、RSS 2.0のフィードも配信したいことがあります。
その方法を紹介します。
1.RSS 2.0のテンプレートの作成
まず、RSS 2.0のテンプレートを作ります。
インデックステンプレートを新規作成し、テンプレート名を「RSS 2.0」、出力ファイル名を「index.xml」として、テンプレートの内容の欄に以下のソースを貼り付けます。
<$MTHTTPContentType type="application/rss+xml"$><?xml version="1.0" encoding="<$MTPublishCharset$>"?> <rss version="2.0"> <channel> <title><$MTBlogName remove_html="1" encode_xml="1"$></title> <link><$MTBlogURL$></link> <description><$MTBlogDescription remove_html="1" encode_xml="1"$></description> <language><$MTBlogLanguage ietf="1"$></language> <copyright>Copyright <$MTDate format="%Y"$></copyright> <lastBuildDate><MTEntries lastn="1"><$MTEntryDate format_name="rfc822"$></MTEntries></lastBuildDate> <generator>http://www.sixapart.com/movabletype/</generator> <docs>http://www.rssboard.org/rss-specification</docs> <MTEntries lastn="15"> <item> <title><$MTEntryTitle remove_html="1" encode_xml="1"$></title> <description><$MTEntryBody encode_xml="1"$></description> <link><$MTEntryPermalink encode_xml="1"$></link> <guid><$MTEntryPermalink encode_xml="1"$></guid> <MTEntryCategories> <category domain="http://www.sixapart.com/ns/types#category"><$MTCategoryLabel remove_html="1" encode_xml="1"$></category> </MTEntryCategories> <MTEntryIfTagged><MTEntryTags> <category domain="http://www.sixapart.com/ns/types#tag"><$MTTagName remove_html="1" encode_xml="1"$></category> </MTEntryTags></MTEntryIfTagged> <pubDate><$MTEntryDate format_name="rfc822"$></pubDate> </item> </MTEntries> </channel> </rss>
2.RSS 2.0へのリンクを出力する
次に、サイドバー等にRSS 2.0へのリンクを出力するようにして、ブログの読者がRSS 2.0のフィードをRSSリーダーに登録しやすくなるようにします。
リンクを出力したい位置に、以下のようなタグを入れます。
<a href="<$mt:BlogURL$>index.xml">RSS 2.0</a>
例えば、Movable Type 4.25の標準テンプレートセットだと、「購読」というウィジェットに、以下のようにAtomのフィードのリンクを出力する部分があります。
<li><img src="<$mt:StaticWebPath$>images/status_icons/feed.gif" alt="購読する" width="9" height="9" /> <a href="<$mt:Link template="feed_recent"$>">このブログを購読</a></li>
この部分を以下のように書き換えれば、AtomとRSS 2.0の両方のリンクを出力することができます。
<li><img src="<$mt:StaticWebPath$>images/status_icons/feed.gif" alt="購読する(Atom)" width="9" height="9" /> <a href="<$mt:Link template="feed_recent"$>">このブログを購読(Atom)</a></li> <li><img src="<$mt:StaticWebPath$>images/status_icons/feed.gif" alt="購読する(RSS 2.0)" width="9" height="9" /> <a href="<$mt:BlogURL$>index.xml">このブログを購読(RSS 2.0)</a></li>
3.RSS 2.0のフィードを検知できるようにする
最近のWebブラウザでは、WebページのHTMLからフィードの情報を検知して、アドレスバーにフィードのアイコンを表示する機能があります。
この機能に対応させて、RSS 2.0のフィードを検知できるようにするには、HTMLのヘッダーを
出力する部分に以下のタグを出力します。
<link rel="alternate" type="application/rss+xml" title="RSS" href="<$mt:BlogURL$>index.xml" />
例えば、Movable Type 4.25の標準テンプレートセットだと、「HTMLヘッダー」というテンプレートモジュールに、以下のようにAtomのフィードの情報を出力する部分があります。
<link rel="alternate" type="application/atom+xml" title="Recent Entries" href="<$mt:Link template="feed_recent"$>" />
この部分を以下のように書き換えることで、AtomとRSS 2.0の両方のフィードを、Webブラウザに検知させることができます。
<link rel="alternate" type="application/atom+xml" title="Recent Entries(Atom)" href="<$mt:Link template="feed_recent"$>" /> <link rel="alternate" type="application/rss+xml" title="Recent Entries(RSS 2.0)" href="<$mt:BlogURL$>index.xml" />