LogoMark.png

PukiWiki/Memo のバックアップの現在との差分(No.0)


#author("2022-10-04T17:48:44+09:00","default:inoue.ko","inoue.ko")
*PukiWiki活用メモ
RIGHT:[[PukiWiki]]
~

***Notes
Login Required
-[[note/PukiWiki1.5.4開発メモ]]
-[[note/PukiWiki1.5.2開発メモ]]
-[[note/PukiWiki1.5.1開発メモ]]
~

#contents2_1
~
~


**編集記法覚書
***公式のテキスト整形ルール
-[[FormattingRules]] 
~

***アンカー
-ページ内の中途、アンカーを置きたい場所に以下のように記載
 &aname(label01); 名称は半角英数
-リンク先の記述を以下のように書けばOK
 [[ページ名#label01]]
~

***上付き文字・下付き文字
default.ini.php 117行目付近 ユーザー定義ルールに以下の2つを追加
 $line_rules = array(

   "SUP{([^}]*)};" => '<span style="vertical-align:super; font-size:60%;">$1</span>',
   "SUB{([^}]*)};" => '<span style="vertical-align:sub; font-size:60%;">$1</span>',
 );

以上の設定により、以下の表記が可能になります。
 上付き:SUP{文字列}; 例) 2 SUP{8}; = 256  
 下付き:SUB{文字列}; 例) - log SUB{2}; P
表示例:2 SUP{8}; = 256  - log SUB{2}; P
~

***下線
default.ini.php 117行目付近 ユーザー定義ルールに以下を追加
 $line_rules = array(

   "__(?!_)((?:(?!__).)*)__" => '<span style="text-decoration:underline;">$1</span>',
 );
以上の設定により、以下の表記が可能になります。
 下線:__アンダーライン__
表示例:__アンダーライン__
~


***サイトマップを作るには
サイト全体のコレクションであれば「一覧」を応用。
必要なページの見出しをコレクションするには以下。
 #ls2([ページ名],title) これを列挙
~
~

**コマンド操作
アドレスバーで、(URL)/index.phpに続けて ?cmd=,  ?plugin= など
~

***コマンドで編集画面に入る(ボタンがない場合)
 http://(URL)/index.php?cmd=edit&page=(ページ名)
~

***ページの一覧を各ページの実ファイル名と共に表示
 http://(URL)/index.php??cmd=filelist
~

***添付の一覧を表示
 http://(URL)/?plugin=attach
// http://(URL)/?plugin=attach&pcmd=list
不要な添付ファイル(添付のバックアップ)はここから「詳細」をクリックして削除可能。
~

***PukiWiki 暗号化テキスト生成
PukiWikiサイトであれば標準機能です。pukiwiki.ini.phpにパスワードを暗号化して記述する場合などに利用
 http://(URL)/index.php?plugin=md5
~
~

**デフォルトシステム

***デバッグモードの利用
index.phpの9行目付近を変更
 error_reporting(E_ERROR | E_PARSE); // Avoid E_WARNING, E_NOTICE, etc
 //error_reporting(E_ALL); // Debug purpose
     ↓
 //error_reporting(E_ERROR | E_PARSE); // Avoid E_WARNING, E_NOTICE, etc
 error_reporting(E_ALL); // Debug purpose

参考:実際、その都度index.phpを書き換えるのは面倒。そこで上記を変更したファイルをdebug.phpとして置いておけば、必要に応じてURLを・・/debug.php?・・にすることでエラーをチェックできる。
~

***クエリ文字列長について
pukiwiki.ini.php 42行目

日本語の長いページ名を扱う場合は、以下のように数値を修正する必要あり。

 //define('PKWK_QUERY_STRING_MAX', 640); // Bytes, 0 = OFF
 define('PKWK_QUERY_STRING_MAX', 1280); // Bytes, 0 = OFF

通常、この変更は必要ないが、長い名称のページの編集においてログインしようとした場合に、制限がかかる。QUERY STRING TOO LONG というエラーメッセージが出てログインできなくなるケースがある場合は、上記のように数値を大きく修正する必要あり。
~

***WikiName(大文字小文字を混ぜた英文字列)を無効にするには

pukiwiki.ini.phpの「$nowikiname」を 「1」に設定

一部のWikiNameのみに適応したい場合は、大文字に当たる部分を全角で入力、または、以下のように数値参照文字を使う。
 &#x57;orldWide
この書き方であれば、WikiName機能を無効にしてWorldWideと表示可。

~

***編集時に ~ を使わずに改行をそのまま反映させたい
pukiwiki.ini.phpの以下の部分を変更
 /////////////////////////////////////////////////
 // 改行を反映する(改行を<br />に置換する)
 $line_break = 0; → $line_break = 1に変更する。
~

***「見出し」の右上の(↑)
見出し右上のナビゲータへのリンク(↑)を消去するには、
default.ini.php で
 $top = $_msg_content_back_to_top  ; ← この行をコメントアウトして
 $top = '';  ←このよう(シングルクオーテーション2つ)にする
~

***「見出し」に自動生成されるダガー:†を消すには
アンカー機能を残しつつ、「†」が表示されないように変更するには
ja.lng.php で
 //$_symbol_anchor   = '&dagger;'; ← この行をコメントアウトして
 $_symbol_anchor   = ' ';   ←全角スペースを定義する
~

***「見出し」に自動生成されるアンカーを無くすには
pukiwiki.ini.php内「Automatically add fixed heading anchor」の項目で
 $fixed_heading_anchor = 0; 
~

***ライセンス文字列 S_COPYRIGHT は
lib/init.php 内に情報あり
~

***listのインデント設定
default.ini を編集
~

***添付ファイルの上限サイズ設定(デフォルト1MBを16MBへ)
-plugin/attach.inc.phpの15行目
 ini_set("upload_max_filesize","2M"); を
 ini_set("upload_max_filesize","16M"); へ
-同じくattach.inc.phpの19行目
 define('PLUGIN_ATTACH_MAX_FILESIZE', (1 * 1024 * 1024)); を
 define('PLUGIN_ATTACH_MAX_FILESIZE', (16 * 1024 * 1024));  へ
~

***添付時に管理者パスワード入力を求めないようにするには
attach.inc.php 23行で
 define('PLUGIN_ATTACH_UPLOAD_ADMIN_ONLY', TRUE);  → FALSEへ
~

***添付の削除時にバックアップを作らないようにするには
attach.inc.php で以下のように設定するとよい。添付のバックアップはディスクを消費するので、作らない方がよい。
 // 管理者が添付ファイルを削除するときは、バックアップを作らない
 // PLUGIN_ATTACH_DELETE_ADMIN_ONLY=TRUEのとき有効
 define('PLUGIN_ATTACH_DELETE_ADMIN_NOBACKUP', TRUE); // FALSE or TRUE
~

***RENAME時に管理者パスワードを求めないように
rename.inc.php を以下のように変更

 --- rename.inc.php.orig	Sat Jul 31 12:09:20 2004
 +++ rename.inc.php	Fri Nov 26 18:16:52 2004
 @@ -273,7 +273,7 @@
     }
   }
   $pass = rename_getvar('pass');
 - if ($pass != '' && pkwk_login($pass))
 + if ($pass != '')
   {
      return rename_proceed($pages, $files, $exists);
   }
 @@ -337,8 +337,7 @@
   <div>
    <input type="hidden" name="plugin" value="rename" />
    $input
 -  {$_rename_messages['msg_adminpass']}
 -  <input type="password" name="pass" value="" /> 
 +  <input type="hidden" name="pass" value="dummy" />
    <input type="submit" value="{$_rename_messages['btn_submit']}" />
   </div>

~

***RecentChangesコマンドで表示される件数
・・・/index.php?RecentChanges で最新の更新一覧が表示されます。
件数は、pukiwiki.ini.php 280行目付近 $maxshowの値で決まります。
 // $whatsnew: Max number of RecentChanges
 $maxshow = 100;
~

***無視ページの設定
pukiwiki.ini.php:491行目付近

 // Regex of ignore pages
 $non_list = '^\:';
最終更新や一覧に表示させたくないページを設定する機能です。
-除外したいページを[[正規表現>RegularExpression]]で記述します。
-以下の例では、「行頭が : ではじまるページ」または「行頭が test ではじまるページ」が無視の対象となります。
 $non_list = '^\:|^test';
--^ は「行頭の」を意味します。
--\ は、直後の「メタ文字( : )」を通常の文字として扱え・・を意味します( \ は [Option]+[¥] で出ます)。
-- | は、論理和(〜または〜)を意味します。
~

***無視ページに該当するものを検索時に表示するか
pukiwiki.ini.php:上記項目の下

 // Search ignored pages
 $search_non_list = 1;(検索対象となって表示される)
0にすると :config 等のシステムファイルは検索時にも無視されます。
~

***無視ページに ignore を設定しても recent に出てしまう。
> cache/recent.dat を一旦削除すればOK

~
~

**プラグイン開発
***articleプラグインの別バージョン
投稿記事の下のコメント入力あり・なしは、プラグインファイル内の以下の部分で変更する必要がある。
 define('PLUGIN_ARTICLE_COMMENT',1);  // 1:入れる 0:入れない
しかし、ユーザーサイドでコメント入力あり・なしを選択できるよう、プラグイン自体を別バージョンにして、article_plus などとして運用したい場合、以下の3箇所を変更することで別バージョンとして動かすことができる。
-function plugin_article_action > function plugin_article_plus_action
-function plugin_article_convert >function plugin_article_plus_convert
-convert 関数内の以下を変更
 <input type="hidden" name="plugin" value="article" />
 → <input type="hidden" name="plugin" value="article_plus" />
~

***search
#lookup で Search を有効にするには、以下を0 に。(デフォルトは1)
ただし、コマンド検索が可能になるので、スパム攻撃受けやすくなる。
 // Allow search via GET method 'index.php?plugin=search&word=keyword'
 // NOTE: Also allows DoS to your site more easily by SPAMbot or worm or ...
 define('PLUGIN_SEARCH_DISABLE_GET_ACCESS', 0); // 1, 0

~


**環境設定
***特定のネットワーク外からのアクセスを不可にするには
.htaccess内に以下の記述を追加
 <Limit GET>
 order deny,allow
 deny from all
 allow from 133.17.
 </Limit>
~
~

**デュアルシステム
''index.php と member.php を用意して、異なる入り口に異なるスキンを適用''
~

***pukiwiki.ini.php
以下をコメントアウトして、pukiwiki.ini.php における SKIN_DIR 設定を無効化
 // Directory settings II (ended with '/')
 // Skins / Stylesheets
 // define('SKIN_DIR', 'skin/');   ← ココ 85行目付近
~

***index.php
以下のような記述を加えて、SKIN_DIR を認識させる
 // Directory definition
 // (Ended with a slash like '../path/to/pkwk/', or '')
 define('DATA_HOME',	'');
 define('LIB_DIR',	'lib/');
 define('SKIN_DIR', 'skin/');  ← ココ 22行目付近(標準スキン)
~

***member.php
以下のような記述を加えて、SKIN_DIR を認識させる
 // Directory definition
 // (Ended with a slash like '../path/to/pkwk/', or '')
 define('DATA_HOME',	'');
 define('LIB_DIR',	'lib/');
 define('SKIN_DIR', 'skin_member/');  ← ココ 22行目付近(専用スキン)
~
~

**その他

***システムファイル :config
以下のようにして閲覧・編集可能
 /path/to/index.php?:config
 /path/to/index.php?:config/plugin/attach/mime-type
~

***プラグインが動作しない
プラグイン名に大文字を使うと、サーバーによっては動かないことがある
 fileName.inc.php → file_name.inc.php
~
***閲覧認証が通らない場合にも、メニュー部分が表示されてしまう問題。
これらも表示されないようにするには、''lib/auth.php'' で 以下のように、表示情報部分をコメントアウトし、echo で最小限のメッセージを表示するよう変更するとよい。

 if ($exit_on_fail) {
   //$body = $title = str_replace('$1',
   //htmlsc(strip_bracket($page)), $title_cannot);
   //$page = str_replace('$1', make_search($page), $title_cannot);
   //catbody($title, $page, $body);
   echo "閲覧には正しいIDとパスワードが必要です";
   exit;
 }
384行目付近

//以下、旧バージョン2
// if ($exit_flag) {
//    //$body = $title = str_replace('$1',
//    //   htmlsc(strip_bracket($page)), $title_cannot);
//    //$page = str_replace('$1', make_search($page), $title_cannot);
//    //catbody($title, $page, $body);
//    echo "閲覧には正しいIDとパスワードが必要です";
//    exit;
// }
//Basic authentication > Auth failed の部分 248行目付近

//以下、旧バージョン
// if ($auth_flag) {
//     header('WWW-Authenticate: Basic realm="' . $_msg_auth . '"');
//     header('HTTP/1.0 401 Unauthorized');
// }
// if ($exit_flag) {  //以下の表示部分をコメントアウト
//     //$body = $title = str_replace('$1',
//     //    htmlspecialchars(strip_bracket($page)), $title_cannot);
//     //$page = str_replace('$1', make_search($page), $title_cannot);
//     //catbody($title, $page, $body);
//     echo "閲覧には正しいIDとパスワードが必要です"; 
//     exit;
// }
~
~

#hr
CENTER:'''''以下、古い情報'''''
#hr
~
~

**PHP8への対応
***新バージョン PukiWiki 1.5.4 を導入
PukiWiki 1.5.4 は、PHP8.1 に対応

~
~

**PHP7への対応
***新バージョンの PukiWiki 1.5.1 を導入
-認証方法含め、かなり変更あり。1.5.0からの変更には提供されているパッチをあてるか、以下の手順で順次確認しつつ移行するのが無難
-PukiWIki 1.5.1 をベースに、
--pukiwiki.ini.php の書き換え
--attach, cash, counter, wiki, 等、コンテンツを投入
--skinについては、pukiwiki.skin.php のシステム部分の記述に変更があるため、稼働中のそれがオリジナルのものである場合には、1.5.1の pukiwiki.skin.php をベースに、必要な部分を書き換える必要があります。
--オリジナルプラグインの投入
~

***プラグインのエラー
 Parse error: syntax error, unexpected 'new' (T_NEW) in
PHP5からPHP7にバージョンを上げた際に上記のエラー
PHP7では新しいオブジェクトを参照渡しで代入ができない・・
 $obj = & new AttachPages2($refer); 
を以下のように修正
 $obj = new AttachPages2($refer);
~
~


**PHP5.5への対応
***新バージョンの PukiWiki 1.5.0 を導入
-基本的には、libフォルダ と pluginフォルダを入れ替えれば問題は解消
-但し、プラグインをカスタマイズしているケースでは、個々に調整が必要
~
~

**PHP5.4系で動かなくなる問題
PukiWiki 1.4.7の継続利用については、とりあえずは、以下の修正で動く
 
-hex2bin関数をコメントアウト
lib/func.php にある「hex2bin」関数が、PHP5.4からネイティブ関数化されているので、これをコメントアウト(以下のようにする)。
 // Inversion of bin2hex()
 /*
 function hex2bin($hex_string)
 {
         // preg_match : Avoid warning : pack(): Type H: illegal hex digit ...
         // (string)   : Always treat as string (not int etc). See BugTrack2/31
         return preg_match('/^[0-9a-f]+$/i', $hex_string) ?
                 pack('H*', (string)$hex_string) : $hex_string;
 }
 */
 
-ls2プラグインの関数呼び出し時の参照渡しを修正
plugin/ls2.inc.php で、関数呼び出し時の参照渡しがされているため、
これを修正。
 array_walk($args, 'plugin_ls2_check_arg', & $params);

 array_walk($args, 'plugin_ls2_check_arg', $params);
 
-オンラインユーザーの表示にも問題。onlineプラグインを修正
plugin/online.inc.php の中に2箇所
 plugin_online_check_online(& $count, $host)
  ↓
 plugin_online_check_online($count, $host)
 

参考:http://pukiwiki.sourceforge.jp/dev/?BugTrack2%2F349

~
~

**PHPがCGIモードでBASIC認証が効かない場合

-解決策1 SESSIONスタイル
plugin フォルダに [[login.inc.php>http://pukiwiki.sourceforge.jp/?%E8%87%AA%E4%BD%9C%E3%83%97%E3%83%A9%E3%82%B0%E3%82%A4%E3%83%B3%2Flogin.inc.php]]を投入
 
lib フォルダ内の auth.php を
login.inc.php用のもので置き換え
※当該プラグインページからDL可 
 
pukiwiki.ini.phpへ
 $auth_type = 'session';session_start();session_regenerate_id(TRUE);
の一行を追加。
 
ただ、このままだと、refで画像表示する回数が増えると編集できなくなる。
そこで、
session_regenerate_id(TRUE) の項目をコメントアウトして
 $auth_type = 'session';session_start();
の記述に変更すると、refで表示する回数を2箇所以上でもOKとなった。
~

-解決策2 DUAL INDEX スタイル
一般閲覧用の pukiwiki.skin.phpからはツールバー部分を削除することで
一見 PukiWikiであることがわからないビジュアルにする。
pukiwiki.ini.php では、$edit_auth = 0;
として、編集認証を用いないようにする

--手順1:index.php をコピーして index_admin.php をつくる
---index.php? :一般閲覧者にアクセスさせる
>ツールバー非表示スキン skin を利用
---index_admin.php? 管理者はここからアクセスする
>ツールバー表示スキン skin_admin を利用
編集は誰でもOK状態とするが、index_admin.php というファイルの名前を非公開(事実上のパスワード)とすることで、事実上、管理者のみが編集できるというかたちにする・・・ という発想。
 見えているサイトがPukiWikiによるものとわかれば、index.phpからでも、コマンドを利用して編集が可能になってしまうが、
 具体的には index.php?cmd=edit&page=ページ名
しかし実際は、よほどの悪意がないかぎり、そうまでして荒らされることはない。一般的な告知を行うのみのサイトでは、これでも実用上は問題ない。
 
--手順2:skinフォルダの設定情報を書き分ける
pukiwiki.ini.php にある、SKIN_DIR という変数が、SKINフォルダの位置。この情報を、pukiwiki.ini.php から消去し、index.php と index_admin.php に移動して、それぞれに異なる SKIN を利用するようにすればよい。
 // Skins / Stylesheets
 define('SKIN_DIR', 'skin/');
---index.php に以下の2行を追加
 // Skins / Stylesheets
 define('SKIN_DIR', 'skin/');
---index_admin.php:に以下の2行を追加
 // Skins / Stylesheets
 define('SKIN_DIR', 'skin_admin/');
 
--手順3:skin フォルダを複製して、skin_admin をつくる
---skin:一般閲覧者用のスキン(ツールバー部分を非表示に)
---skin_admin:管理者用のスキン
 
--手順4:index_admin.php が検索でかからないよう設定する
skin_admin 内  pukiwiki.skin.php の metaname 部分を以下のように変更 
<meta name="robots" content="NOINDEX,NOFOLLOW" />

//index_admin.php の 23 24 行めあたりに以下の2行を追加
//
//define('SKIN_DIR',	'skin/');
//define('SKIN_FILE', DATA_HOME . SKIN_DIR . 'pukiwiki.skin_admin.php');
//
//pukiwiki.skin.php を複製して pukiwiki.skin_admin.php をつくる
//
~
~

**yesterdayのカウントが0になってしまう場合
plugin/couter.inc.php ファイル内86行目を以下のように修正する。
-× get_date('Y/m/d', strtotime('yesterday', UTIME)));
-○ get_date('Y/m/d', strtotime('yesterday'))); 
~
~

**Kcaptchaで画像が表示されない
-PHPにGDがインストールされている必要がある。
-GD for PHP5 を追加インストールしたら解決
~
~

**Flashが最前面にきてしまう問題の解決策
//http://web-conte.com/blue/200610/23_1952.php より
Flashオブジェクトは z-indexなどの指定を無視して、基本的にドキュメントの最前面に表示される。これを解決するにはFlashを埋め込む際、背景を透過する命令を書き加えればいい。
-object要素内に下記を追加
 <param name="wmode" value="transparent" />
- embed要素の属性に下記を追加
 wmode="transparent"

芸学サイトのトップのスライドについては、以下のとおり変更

-オリジナル
 function flash_activate(){
  	// ---- initialize tag string ----
   var strObj  = '<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" ';
   var strPrm  = ''; 
   var strEmb  = '<embed ';

-変更後
 function flash_activate(){
 	// ---- initialize tag string ----
   var strObj  = '<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" ';
   var strPrm  = '<param name="wmode" value="transparent" />'; // ここ変更
   var strEmb  = '<embed wmode="transparent" '; // ここ変更
~
~