0byt3m1n1
Path:
/
data
/
applications
/
aps
/
geeklog
/
1.8.0-0
/
standard
/
htdocs
/
public_html
/
docs
/
japanese
/
[
Home
]
File: staticpages.html
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <meta http-equiv="Content-Style-Type" content="text/css"> <title>静的ページプラグイン | Geeklogドキュメント</title> <link rel="stylesheet" type="text/css" href="../docstyle.css" title="Dev Stylesheet"> <link rel="stylesheet" type="text/css" href="docstyle.css" title="Dev Stylesheet"> </head> <body> <p><a href="http://www.geeklog.jp" style="background:transparent"><img src="../images/newlogo.gif" alt="Geeklog Documentation" width="243" height="90"></a></p> <div class="menu"><a href="index.html">Geeklogドキュメント</a> - 静的ページプラグイン</div> <h1>静的ページプラグイン</h1> <h2><a name="about">概要</a></h2> <p>静的ページプラグインは、本来、(Geeklogが作成する動的ページとは対照的に)静的コンテンツを持ったページを作成するためのものでした。そういうわけで「静的」という名前になっています。「このサイトについて」や「目標宣言」などのページが思い浮かぶでしょう。</p> <p>その時以来、人々は様々な目的で静的ページを使用しています。静的ページにPHPのコードを含めることができるようになっていますので、静的ページという名前はもはやだいぶ不適切なものになっています。</p> <h2><a name="features">機能</a></h2> <ul> <li><a href="#php">PHPの使用</a>をサポート</li> <li>読みやすいURLを作成するための<a href="#id">編集可能なページID</a></li> <li>静的ページをGeeklogの<a href="#frontpage">インデックスページと話題ページ</a>に、さらに全画面表示("スプラッシュスクリーン機能")にも表示可能</li> <li>既存のページを<a href="#cloning">コピーする</a>機能</li> <li>Geeklogの<a href="#url">URL書き換え</a></li> <li><a href="#autotags">2つの自動タグ</a>を実装</li> <li>Geeklogのパーミッションシステムを適切にサポート</li> </ul> <h2><a name="php">PHPの使用</a></h2> <h3><a name="activation">PHPを使えるようにする</a></h3> <p><strong>重要:</strong> セキュリティ上の理由で、静的ページでのPHP使用はデフォルトでは無効になっています。有効にするには、Static Page Adminグループに、<code>staticpages.PHP</code>権限を与える必要があります。そのためには、管理者としてログインし、管理者用メニューから「グループ」を選択します。Static Page Adminを見つけて、グループ名の左側にある編集アイコン(ペンの形)をクリックします。ページの下の方に「権限(Rights)」のリストがあり、<code>staticpages.delete</code>と<code>staticpages.edit</code>には既にチェックが入っています。Static Page Adminグループに属する人が静的ページでPHPを使えるようにするには、<code>staticpages.PHP</code>にチェックを入れてから保存をクリックします。</p> <p>上述の <code>staticpages.PHP</code> 権限に加えて、静的ページ全体でPHPの使用を無効にするグローバルなオプションもあります。このオプションは「管理者用メニュー - コンフィギュレーション - 静的ページ」の中にある「PHPを許可する」です。「いいえ」にすると、<code>staticpages.PHP</code>よりも優先され、静的ページの中でPHPを使えなくなります。</p> <h3><a name="usage">使用法</a></h3> <p style="text-align:center"><em>静的ページでPHPを不適切に使用すると、セキュリティの問題が発生する可能性があります。注意して使用してください。</em></p> <p>静的ページごとにPHPの使用を有効にする必要があります。コンテンツ編集欄の下に、次の選択肢のあるPHPのドロップダウンリストがあります。</p> <ul> <li>PHPを実行しない<br> 静的ページの中にPHPのコードが含まれていても、<em>実行されず</em>、コードがそのまま表示されます。</li> <li>PHPを実行する(return)<br> 静的ページに含まれるPHPのコードが<em>実行されます</em>。'return'とは、このページが表示する内容をPHPのコードで(<code>echo</code> 文や <code>print</code> 文を使って)直接出力する代わりに <code>return</code> 文で返すことを意味します。これは静的ページプラグイン ver 1.3から導入されたオプションです。</li> <li>PHPを実行する<br> 静的ページに含まれるPHPのコードが<em>実行されます</em>。このオプションを使うと、ページレイアウトに干渉することなくPHPの<code>echo</code>文や<code>print</code>文を使ってページの内容を出力できます。</li> </ul> <p>静的ページにPHPのコードを埋め込むときに、PHPの<code><?php</code>タグと<code>?></code>タグを<em>記述してはいけません</em>。静的ページに含まれるPHPのコードは、Geeklog側でこれらのタグを付加されて実行されるからです。</p> <p>上述の「PHPを実行する」(returnなしの方)を選択する場合は、コードの中でPHPとHTMLを次のように行き来することができます。</p> <pre style="padding-left: 2em"><code>echo "Hello"; ?>, <b>world</b>, <?php echo "how are you?";</code></pre> <p>この例では、"Hello, <b>world</b>, how are you?"と表示されます。</p> <h2><a name="id">ページID</a></h2> <p>静的ページを新規作成すると、ページIDが自動的に割り当てられます。このIDは日付・時刻と最大3桁のランダムな数字で構成されています。このページのURLを頻繁に使用するつもりなら(Eメールで引用する場合など)、もっと読みやすいページIDにするのは意味のあることでしょう。</p> <p>「静的ページの編集」では、ページIDを変えることもできます。たとえば、「当サイトに関して」のページのIDを"20030313100131123"から"about"に変えて、次のURLにできます。</p> <p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php?page=about</tt></p> <p>こちらの方が遙かに引用しやすいし、覚えやすいです。Geeklogの<a href="#url">URLリライト機能</a>を活用してさらに改善することもできるでしょう。</p> <p>ページIDで安全に使える文字はアルファベットと数字だけです。各国固有の文字(ひらがな、カタカナ、漢字など)やほとんどの句読点(とはいえ、'-' と '.' は使えるはずです)、スペースは使用しないでください。「静的ページの編集」は一部の不正な文字を検出しますが、全部というわけではありません。</p> <h2><a name="frontpage">静的ページをインデックスページで使用する</a></h2> <p>Geeklogのセンターブロックの概念では、プラグインがサイトのセンターエリア(つまり、記事と記事の間)にブロックを出力することを許可しています。</p> <p>「静的ページの編集」で「センターエリア」にチェックを入れると、静的ページを表示する場所を選択するために、「表示エリア」と「話題」というドロップダウンリストが使えるようになります。「表示エリア」で選べるのは、「ページの最上部」、「注目記事の下」、「ページの下」(この3つは説明不要でしょう)と「ページ全体」です。最後の「ページ全体」とは、この静的ページがインデックスページとして表示される、つまり、通常の記事が一切表示されなくなるということです。サイトの「スプラッシュ画面」や「ようこそ」ページを作成するのに役に立つでしょう。</p> <p><strong>ヒント:</strong> 静的ページをスプラッシュ画面として使用する場合、訪問者を普通のインデックスページへ誘導するリンクが必要になることもあるでしょう。この場合は、静的ページの中に<code>index.php?display=all</code>というリンクを作成すればよいでしょう。</p> <p>2番目の「話題」ドロップダウンリストを使うと、静的ページの表示を特定の話題、ホームページ(トップページ)のみ、全ページ(つまり、すべての話題 + ホームページ)に限定できます。これはブロックを表示するオプションと全く同じです。</p> <p><strong>ヒント:</strong> これらのオプションをパーミッションと組み合わせることもできます。たとえば、ゲストユーザにしか表示されない「ようこそ」ページを作成することも可能です。</p> <h3><a name="sort">ソート(並べ換え)</a></h3> <p><strong>センターブロックでのソート項目:</strong> センターエリアの同一セクション内(たとえば、インデックスページのトップに静的ページを2つ表示する場合)に複数の静的ページを表示させる場合、「管理者用メニュー - コンフィギュレーション - 静的ページ」で表示順を選ぶことができます。選択肢は、次の通りです。</p> <ul> <li>日付(更新日時の新しい順に並べ換え)</li> <li>ページID(ページIDで並べ換え:デフォルト)</li> <li>タイトル(ページのタイトルで並べ換え)</li> </ul> <p>この順序が適用されるのは、センターブロック内の静的ページだけです。センターブロックを出力する他のプラグインはこの順序には含まれません。また、センターブロックは普通のGeeklogのブロックのような外見をしているとは限りません。この目的のためには、下にある「ページをブロックで囲む」を「はい」にします。</p> <p><strong>メニューでのソート項目:</strong> サイトのメニューに表示される静的ページを並べ換えることもできます(<tt>header.thtml</tt> テンプレートファイル内で、 <code>{plg_menu_elements}</code> 変数を使用している場合)。この項目も「管理者用メニュー - コンフィギュレーション - 静的ページ」で表示順を選ぶことができます。選択肢は、次の通りです。</p> <ul> <li>日付(更新日時の新しい順に並べ換え)</li> <li>ラベル(メニューに表示される文字列:デフォルト)</li> <li>ページID(ページIDで並べ換え:デフォルト)</li> <li>タイトル(ページのタイトルで並べ換え)</li> </ul> <h2><a name="block">静的ページをブロックで囲む</a></h2> <p>「静的ページの編集」で「ブロックで囲む」をチェックすると、静的ページをGeeklogのブロックレイアウトで囲むことができます。この場合、静的ページのタイトルがブロックのタイトルとして使用されます。また、普通のブロックと同様にヘルプ表示用のURLを入力することもできます。URLを入力すると、そのURLにリンクするヘルプアイコンが表示されます。</p> <p>このオプションのデフォルトは、「管理者用メニュー - コンフィギュレーション - 静的ページ」で設定することができます。</p> <h2><a name="cloning">静的ページをコピーする</a></h2> <p>同じような静的ページがたくさんある場合、既存のページをコピーしてから編集したいでしょう。静的ページのリストで、コピー欄のアイコンをクリックすれば簡単にコピーできます。コピーすると新たなページIDがついたページができます。</p> <h2><a name="url">URLリライト</a></h2> <p style="margin-left:4em;"><em>この機能は実験的なものであり、<acronym title="Internet Information Service">IIS</acronym>では動作しないことが知られています。</em></p> <p>Geeklogはある種のURL書き換え、つまり、URLの外観を検索エンジンに拾われやすいものにする機能を持っています。たとえば、</p> <p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php?page=20030313100131123</tt></p> <p>の代わりに、次のような外観にすることができます。</p> <p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php/20030313100131123</tt></p> <p>検索エンジンの中には、URLに '?' や '=' などの文字が含まれていると、そのページをインデックスに登録しないものがあるということが知られています。これをさらに推し進めて、<a href="#id">数字で構成されたページID</a>を(できれば、ページの内容と関連する)単語や表現に置き換えることで、検索エンジンにさらに登録されやすくすることもできるでしょう。</p> <p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php/about</tt></p> <p>URL書き換えを行うには、「管理者用メニュー - コンフィギュレーション - Geeklog - サイト」で「URLリライト」を「はい」にする必要があります。</p> <h2><a name="delete">所有者の削除と共に削除する</a></h2> <p>Geeklogのすべてのオブジェクト同様、静的ページには所有者(そのページの作成者)がいます。そのユーザのアカウントが何らかの理由で削除された場合、そのユーザが所有していた静的ページも削除するか、GeeklogのRootグループに属する人に引き継がせることができます。</p> <p>「管理者用メニュー - コンフィギュレーション - 静的ページ」で「<a href="#desc_delete_pages">所有者の削除と共に削除する</a>」を「いいえ」(デフォルト)にすると、所有者が削除されても作成した静的ページは削除されず、Rootグループのメンバ(ユーザIDが最も若い人、つまり、たいていはサイトの管理者)に引き継がれます。「はい」にすると、所有者のアカウントが削除されたとき、作成した静的ページも削除されます。</p> <h2><a name="config.php">コンフィギュレーション</a></h2> <p>静的ページプラグインのコンフィギュレーションオプションは、コンフィギュレーション管理画面で変更します。</p> <h3><a name="main">静的ページの主な設定</a></h3> <table> <tr><th style="width:25%">項目(変数)</th> <th style="width:25%">デフォルト</th> <th style="width:50%">説明</th> </tr> <tr> <td><a name="desc_allow_php">PHPを許可する(allow_php)</a></td> <td><code>はい</code></td> <td>静的ページにおいて、<a href="#php">PHPを許可する</a>。つまり、この設定で、個々のページの設定を上書きします</td> </tr> <tr class="r2"> <td><a name="desc_sort_by">センターブロックでのソート項目(sort_by)</a></td> <td><tt>ページID</tt></td> <td>センターブロックに静的ページが複数表示される場合の順番を設定します。ページID、ページタイトル、最後に編集した日付から選べます。</td> </tr> <tr> <td><a name="desc_sort_menu_by">メニューでのソート項目(sort_menu_by)</a></td> <td><tt>ラベル</tt></td> <td>サイトメニューの順番を設定します。ページラベル、ページID, ページタイトル、最後に編集した日付から選べます。</td> </tr> <tr class="r2"> <td><a name="desc_sort_list_by">ソート順(sort_list_by)</a></td> <td>タイトル</td> <td>管理者専用画面で表示するソート順のデフォルトを指定します。 所有者ID順, ページID順, ページタイトル順, そして編集日付順です。</td> </tr> <tr> <td><a name="desc_delete_pages">所有者の削除と共に削除する(delete_pages)</a></td> <td><tt>いいえ</tt></td> <td>ページの所有者のアカウントが削除された場合、つまりその静的ページを最初に作成したユーザが居なくなった場合、そのページを'True'なら削除、'False'なら"Root"グループのユーザ(通常は最も小さい値のIDのRootユーザ)に変更します。</td> </tr> <tr class="r2"> <td><a name="desc_in_block">ページをブロックで囲む(in_block)</a></td> <td><tt>はい</tt></td> <td>静的ページを作成する際、ページをブロックで囲むモードのデフォルトを設定します。</td> </tr> <tr> <td><a name="desc_show_hits">閲覧数を表示する(show_hits)</a></td> <td><tt>いいえ</tt></td> <td>閲覧回数を表示するかどうかを設定します。</td> </tr> <tr class="r2"> <td><a name="desc_show_date">日時を表示する(show_date)</a></td> <td><tt>はい</tt></td> <td>最後に編集した日時を表示するかどうかを設定します。</td> </tr> <tr> <td><a name="desc_filter_html">HTMLフィルターを適用する(filter_html)</a></td> <td><tt>いいえ</tt></td> <td>GeeklogのHTMLフィルターを静的ページの編集時に適用させるかどうかを設定します。</td> </tr> <tr class="r2"> <td><a name="desc_censor">内容を検閲する(censor)</a></td> <td><tt>いいえ</tt></td> <td>Geeklogの"バッドワード"フィルターを静的ページの編集時に適用させるかどうかを設定します。 </td> </tr> <tr> <td><a name="desc_aftersave">ページ保存後の画面遷移(aftersave)</a></td> <td><tt>静的ページ管理を表示する</tt></td> <td>静的ページ保存後の画面遷移を設定します: <ul> <li>編集した静的ページを表示します。</li> <li>静的ページ管理を表示します(デフォルト)。</li> <li>Home(サイトのトップページ)を表示します。</li> <li>管理画面トップを表示します。</li> </ul></td> </tr> <tr class="r2"> <td><a name="desc_atom_max_items">フィードに書き出す最大ページ数(atom_max_items)</a></td> <td>10</td> <td>WebサービスAPIによってatomフィードに書き出す静的ページ数の最大値を指定します。</td> </tr> <tr> <td><a name="desc_meta_tags">メタタグ(meta_tags)</a></td> <td>false</td> <td>静的ページが表示されたときメタタグをセットするかどうかを指定します。</td> </tr> <tr class="r2"> <td><a name="desc_comment_code">コメントコード(comment_code)</a></td> <td>-1</td> <td>静的ページにコメントを許可 (0) または不可 (-1) を指定します。 これは静的ページ新規作成時のデフォルトとなり、すべての静的ページに対してモードが上書きされます。</td> </tr> <tr> <td><a name="desc_draft_flag">ドラフトフラグ(draft_flag)</a></td> <td>0</td> <td>静的ページのデフォルト: ドラフトフラグ ON (1) または OFF (0) を指定します。</td> </tr> </table> <h3><a name="whatsnew">新着ブロック</a></h3> <table> <tr><th style="width:25%">項目(変数)</th> <th style="width:25%">デフォルト</th> <th style="width:50%">説明</th> </tr> <tr> <td valign="top"><a name="desc_newstaticpagesinterval">静的ページの"新着"期間(newstaticpagesinterval)</a></td> <td valign="top">1209600秒 (= 2週間)</td> <td valign="top">静的ページが新着ブロックに表示される期間を秒数で指定します。</td></tr> <tr class="r2"> <td valign="top"><a name="desc_hidenewstaticpages">新着ブロック表示(hidenewstaticpages)</a></td> <td valign="top">表示しない</td> <td valign="top">新着ブロックに、'表示しない'、'作成日付によって表示する'、'編集日付によって表示する'を選択します。</td></tr> <tr> <td valign="top"><a name="desc_title_trim_length">タイトルトリミング文字数(title_trim_length)</a></td> <td valign="top">20</td> <td valign="top">新着ブロックに表示するタイトルのトリミングの文字数を指定します。</td></tr> <tr class="r2"> <td valign="top"><a name="desc_includecenterblocks">センターブロックのページを含む(includecenterblocks)</a></td> <td valign="top">いいえ</td> <td valign="top">センターブロックに表示する静的ページを含むかどうかを指定します。</td></tr> <tr> <td valign="top"><a name="desc_includephp">PHPモードのページを含む(includephp)</a></td> <td valign="top">いいえ</td> <td valign="top">PHPモードの静的ページを含むかどうかを指定します。</td></tr> </table> <h3><a name="search">検索結果</a></h3> <table> <tr><th style="width:25%">項目(変数)</th> <th style="width:25%">デフォルト</th> <th style="width:50%">説明</th> </tr> <tr> <td valign="top"><a name="desc_includesearch">検索結果に含ませる(includesearch)</a></td> <td valign="top">true</td> <td valign="top">検索結果に静的ページを含ませるかどうかを指定します。</td></tr> <tr class="r2"> <td valign="top"><a name="desc_includesearchcenterblocks">センターブロックのページを含ませる(includesearchcenterblocks)</a></td> <td valign="top">false</td> <td valign="top">検索結果にセンターブロックの静的ページを含ませるかどうかを指定します。</td></tr> <tr> <td valign="top"><a name="desc_includesearchphp">PHPモードのページを含ませる(includesearchphp)</a></td> <td valign="top">false</td> <td valign="top">検索結果にPHPモードの静的ページを含ませるかどうかを指定します。</td></tr> </table> <h2><a name="autotags">自動タグ</a></h2> <p>静的ページプラグインは、<code>[staticpage:]</code> と <code>[staticpage_content:]</code> という2つの<a href="http://www.geeklog.net/article.php/autolinks" title="geeklog.net: About Autolinks and Autotags">自動タグ</a>を提供します。</p> <ul> <li><code>[staticpage:]</code> 自動タグは静的ページへのリンクに置き換えられます。コロンの後に静的ページのIDを記述してください。既定では、そのページのタイトルがリンクテキストとして使用されます。静的ページIDの後に半角スペースに続けて独自のリンクテキストを指定することもできます(閉じカッコの前でなければなりません)。</li> <li><code>[staticpage_content:]</code> 自動タグは、静的ページの内容に置き換えられます。複数の箇所で同一テキストを使用する際に役に立つでしょう。</li> </ul> <div class="footer"> <a href="http://wiki.geeklog.net/">Geeklogドキュメント作成プロジェクト</a>、<a href="http://wiki.geeklog.jp/">Geeklogドキュメント日本語版作成プロジェクト</a><br> 本ページのすべての商標と著作権はそれぞれの所有者に帰属します。Geeklogはコピーレフトです。 </div> </body> </html>