HypCommonPreLoad[1] に含まれる出力フィルターで、XOOPS[6]を丸ごと携帯対応にすることができます。
ここに解説のある設定項目でも hypconf モジュールで設定できる項目は、そちらで設定したほうが、はるかに簡単に設定できます。ぜひ、hypconf モジュールをインストール[18]してご活用ください。
hypconf モジュールは、HypCommonFunc[7] に含まれています。html/modules/hypconf, xoops_trust_path[9]/modules/hypconf の各ディレクトリをサーバーの html側 と trustパス側へそれぞれ間違えないようにアップロードして、XOOPS[6] のモジュール管理からインストール[18]してください。
"XOOPS_TRUST_PATH[9]/class/hyp_common/preload/hyp_preload.conf.php" を編集して設定をします。該当ファイルがない場合は、同じディレクトリに含まれている "hyp_preload.conf.php.rename" をリネームしてください。
// 各機能のメインスイッチ (On = 1, Off = 0)
$this->use_set_query_words = 0; // 検索ワードを定数にセット
$this->use_words_highlight = 0; // 検索ワードをハイライト表示
$this->use_proxy_check = 0; // POST時プロキシチェックする
$this->use_dependence_filter = 0; // 機種依存文字フィルター
$this->use_post_spam_filter = 0; // POST SPAM フィルター
$this->post_spam_trap_set = 0; // 無効フィールドのBot罠を自動で仕掛ける
$this->use_k_tai_render = 0; // 携帯対応レンダーを有効にする
$this->use_smart_redirect = 0; // スマートリダイレクトを有効にする
// 各種設定
$this->configEncoding = 'EUC-JP'; // このファイルの文字コード
$this->encodehint_word = 'ぷ'; // POSTエンコーディング判定用文字
$this->encodehint_name = 'HypEncHint'; // POSTエンコーディング判定用 Filed name
$this->detect_order = 'ASCII, JIS, UTF-8, eucJP-win, EUC-JP, SJIS-win, SJIS';
$this->msg_words_highlight = 'これらのキーワードがハイライトされています';
$this->no_proxy_check = '/^(127\.0\.0\.1|192\.168\.1\.)/'; // 除外IP
$this->msg_proxy_check = 'Can not post from public proxy.';
// Input filter 制御文字の除去
// 0: null 以外許可, 1: SoftBankの絵文字と\t,\r,\n は許可, 2: \t,\r,\n のみ許可
$this->input_filter_strength = 0;
// POST SPAM
$this->use_mail_notify = 1; // POST SPAM メール通知 0:なし, 1:SPAM判定のみ, 2:すべて
$this->send_mail_interval = 60; // まとめ送りのインターバル(分) (0 で随時送信)
$this->post_spam_a = 1; // <a> タグ 1個あたりのポイント
$this->post_spam_bb = 1; // BBリンク 1個あたりのポイント
$this->post_spam_url = 1; // URL 1個あたりのポイント
$this->post_spam_unhost= 5; // 不明 HOST の加算ポイント
$this->post_spam_host = 31; // Spam HOST の加算ポイント
$this->post_spam_word = 10; // Spam Word の加算ポイント
$this->post_spam_filed = 200; // Spam 無効フィールドの加算ポイント
$this->post_spam_trap = '___url';// Spam 罠用無効フィールド名
$this->post_spam_user = 150; // POST SPAM 閾値: ログインユーザー
$this->post_spam_guest = 15; // POST SPAM 閾値: ゲスト
$this->post_spam_badip = 100; // アクセス拒否リストへ登録する閾値
// 処理をパスするフォームフィールド名 (,<カンマ> 区切り)
// reference_quote : d3forum
// msg_before,msg_after : PukiWikiMod
$this->post_spam_pass_names = 'reference_quote,msg_before,msg_after';
// Protector 併用設定 (Protector の拒否IP登録の保護グループ設定も有効)
$this->post_spam_badip_ttl = 900; // アクセス拒否の拒否継続時間[Sec](0:無期限,null:Protector不使用)
$this->post_spam_badip_forever = 200; // 無期限アクセス拒否閾値
$this->post_spam_badip_ttl0 = 2592000; // 無期限アクセス拒否継続時間[Sec](0:本当に無期限)
// Proxy Checkers
$this->post_spam_checkers = array(
//'list.dsbl.org',
'niku.2ch.net',
array(
'dnsbl.spam-champuru.livedoor.com',
'/^192\.168\.1\.2/'
),
);
// POST SPAM のポイント加算設定
$this->post_spam_rules = array(
// 同じURLが1行に3回 11pt
"/((?:ht|f)tps?:\/\/[!~*'();\/?:\@&=+\$,%#\w.-]+).+?\\1.+?\\1/i" => 11,
// 65文字以上の英数文字のみで構成されている 15pt
// '/^[\x00-\x7f\s]{65,}$/' => 15,
// 無効な文字コードがある 31pt
'/[\x01-\x08\x0b-\x0c\x0e\x10-\x1a\x1c-\x1f\x7f]+/' => 31,
// よくあるSPAM 15pt
'/^\s*(?:Hi|Aloha)! (?:<a[^>]+?href=|\[url=|http:\/\/)/i' => 15,
);
// 無効なフィールド定義
$this->ignore_fileds = array(
// 'url' => array('newbb/post.php', 'comment_post.php'),
);
// 検索ワード定数名
$this->q_word = 'XOOPS_QUERY_WORD'; // 検索ワード
$this->q_word2 = 'XOOPS_QUERY_WORD2'; // 検索ワード分かち書き(分かち書き不使用なら空文字''で設定)
$this->se_name = 'XOOPS_SEARCH_ENGINE_NAME'; // 検索元名
// 外部リンクに付加する class属性値
// use_words_highlight = 1 の場合に有効
// 空値指定で class属性の付加なし
$this->extlink_class_name = 'ext';
// KAKASI での分かち書き結果のキャッシュ先
$this->kakasi_cache_dir = XOOPS_TRUST_PATH[9].'/uploads/hyp_common/kakasi/';
// スマートリダイレクトのポップアップ最短秒数
$this->smart_redirect_min_sec = 5;
// 定数 "HYP_IS_BOT_UA" をセットする UserAgant PCRE 正規表現
$this->bot_ua_reg = '/bot|Slurp|Crawler|Sidewinder|spider|Y!J|Ask/i';
/////////////////////////
// 携帯対応レンダー設定
// 携帯端末判定用 UA 正規表現
$this->k_tai_conf['ua_regex'] = '#(?:Android|Windows Phone|SoftBank|Vodafone|J-PHONE|DoCoMo|UP\.Browser|DDIPOCKET|WILLCOM|iPhone|iPod|mixi-mobile-converter|Googlebot-Mobile|Google Wireless Transcoder|Hatena-Mobile-Gateway)#';
// jQuery mobile を使用するプロファイル
$this->k_tai_conf['jquery_profiles'] = 'android,iphone,ipod,windows phone';
// jQuery mobile のテーマ
// ページ
$this->k_tai_conf['jquery_theme'] = 'b';
// メインコンテンツ
$this->k_tai_conf['jquery_theme_content'] = 'd';
// ブロックコンテンツ
$this->k_tai_conf['jquery_theme_block'] = 'c';
// jQuery 使用時はHTMLの携帯用変換を行わない
$this->k_tai_conf['jquery_no_reduce'] = true;
// jQuery Mobile 適用時に Flash を除去するプロファイル名をカンマ区切りで記述。
$this->k_tai_conf['jquery_remove_flash'] = ''; // 'iphone,ipod,ipad'
// jQuery Mobile 適用時に入れ子になっているテーブルを展開する。
$this->k_tai_conf['jquery_resolve_table'] = false;
// jQuery Mobile 適用時に画像を指定幅[px]サイズまで縮小する。「0」で無効。
$this->k_tai_conf['jquery_image_convert'] = 0;
// HTML再構築用タグ設定
$this->k_tai_conf['rebuilds'] = array(
'header' => array( 'above' => '',
'below' => ''),
'body' => array( 'above' => '',
'below' => ''),
'footer' => array( 'above' => '',
'below' => ''),
'headerlogo' => array( 'above' => '<center>',
'below' => '</center>'),
'headerbar' => array( 'above' => '<hr>',
'below' => ''),
'breadcrumbs' => array( 'above' => '',
'below' => ''),
'leftcolumn' => array( 'above' => '<hr>',
'below' => ''),
'centerCcolumn' => array( 'above' => '<hr>',
'below' => ''),
'centerLcolumn' => array( 'above' => '',
'below' => ''),
'centerRcolumn' => array( 'above' => '',
'below' => ''),
'content' => array( 'above' => '<hr>',
'below' => ''),
'rightcolumn' => array( 'above' => '<hr>',
'below' => ''),
'footerbar' => array( 'above' => '',
'below' => ''),
'easylogin' => array( 'above' => '<div style="text-align:center;background-color:#DBBCA6;font-size:small">[ ',
'below' => ' ]</div>'),
'redirectMessage'=> array( 'above' => '<marquee loop="3">',
'below' => '</marquee>'),
'blockMenu' => array( 'above' => '<div style="background-color:#E0EEEE;font-size:small">',
'below' => '</div>'),
'blockContent' => array( 'above' => '',
'below' => ''),
'toMain' => array( 'above' => '<hr /><div style="text-align:center">',
'below' => '</div>'),
'subMenu' => array( 'above' => '<div id="submenu" style="background-color:#ccccff"><h2 style="text-align:center">サブメニュー</h2></div>',
'below' => ''),
);
// jQuery Mobile 上書き用
$this->k_tai_conf['rebuildsEx']['jqm'] = array(
'header' => array( 'above' => '<div data-role="header" data-theme="'.$this->k_tai_conf['jquery_theme'].'">',
'below' => '</div>'),
'body' => array( 'above' => '<div data-role="content" id="keitaiContents" data-theme="'.$this->k_tai_conf['jquery_theme'].'">',
'below' => '</div>'),
'footer' => array( 'above' => '<div data-role="footer" data-theme="'.$this->k_tai_conf['jquery_theme'].'">',
'below' => '</div>'),
'easylogin' => array( 'above' => '',
'below' => ''),
'blockMenu' => array( 'above' => '<div data-role="header" style="line-height:1">',
'below' => '</div>'),
);
// 携帯用XOOPS[6]テーマセット
$this->k_tai_conf['themeSet'] = 'ktai_default';
$this->k_tai_conf['themeSets'] = array();
//$this->k_tai_conf['themeSets']['jqm'] = ''; // jQuery mobile 一括
// carrier 別の設定 (carrier をキーにして設定)
//$this->k_tai_conf['themeSets']['android'] = '';
//$this->k_tai_conf['themeSets']['iphone'] = '';
//$this->k_tai_conf['themeSets']['ipod'] = '';
//$this->k_tai_conf['themeSets']['windows phone'] = '';
// 携帯用XOOPS[6]テンプレートセット
$this->k_tai_conf['templateSet'] = '';
$this->k_tai_conf['templateSets'] = array();
//$this->k_tai_conf['templateSets']['jqm'] = ''; // jQuery mobile 一括
// carrier 別の設定 (carrier をキーにして設定)
//$this->k_tai_conf['templateSets']['android'] = '';
//$this->k_tai_conf['templateSets']['iphone'] = '';
//$this->k_tai_conf['templateSets']['ipod'] = '';
//$this->k_tai_conf['templateSets']['windows phone'] = '';
// 使用テンプレート
$this->k_tai_conf['template'] = 'default';
$this->k_tai_conf['templates']['jqm'] = 'smart'; // jQuery mobile 用
// <body> attributes
$this->k_tai_conf['bodyAttribute'] = '';
// 無効にするブロックの bid (Block Id) (無指定:フィルタリングしない)
$this->k_tai_conf['disabledBlockIds'] = array();
// 有効にするブロックの bid (Block Id) (無指定:フィルタリングしない)
$this->k_tai_conf['limitedBlockIds'] = array();
// 常に表示するブロックの bid (Block Id) (メインメニューなど)
$this->k_tai_conf['showBlockIds'] = array();
// インラインイメージのリサイズ最大ピクセル
$this->k_tai_conf['pictSizeMax'] = '200';
// インラインイメージを表示するホスト名(後方一致)
$this->k_tai_conf['showImgHosts'] = array('amazon.com', 'yimg.jp', 'yimg.com', 'google.com');
// 直接画像を表示するホスト名(後方一致)
$this->k_tai_conf['directImgHosts'] = array('google-analytics.com', 'maps.google.com', 'ad.jp.ap.valuecommerce.com', 'ba.afl.rakuten.co.jp', 'assoc-amazon.jp', 'ad.linksynergy.com');
// リダイレクトスクリプトを経由しないホスト名(後方一致)
$this->k_tai_conf['directLinkHosts'] = array('amazon.co.jp', 'ck.jp.ap.valuecommerce.com', 'afl.rakuten.co.jp', 'maps.google.com');
// 外部リンク用リダイレクトスクリプト
$this->k_tai_conf['redirect'] = XOOPS_URL . '/class/hyp_common/gate.php?way=redirect&_d=0&_u=0&_x=0&l=';
// Easy login を有効にする
$this->k_tai_conf['easyLogin'] = 1;
// Easy login で IP アドレス帯域をチェックしない
$this->k_tai_conf['noCheckIpRange'] = 0;
// docomo の端末IDを確認する間隔(秒)
$this->k_tai_conf['docomoGuidTTL'] = 300;
// リンクメッセージ
$this->k_tai_conf['msg']['easylogin'] = '簡単ログイン';
$this->k_tai_conf['msg']['logout'] = 'ログアウト';
$this->k_tai_conf['msg']['easyloginSet'] = '簡単ログイン:設定';
$this->k_tai_conf['msg']['easyloginUnset'] = '簡単ログイン:解除';
$this->k_tai_conf['msg']['toMain'] = '本文を表示';
$this->k_tai_conf['msg']['mainMenu'] = 'メインメニュー';
$this->k_tai_conf['msg']['subMenu'] = 'サブメニュー';
$this->k_tai_conf['msg']['switchSmart'] = 'スマホスタイルへ';
// アイコン
$this->k_tai_conf['icon']['first'] = '';
$this->k_tai_conf['icon']['prev'] = '';
$this->k_tai_conf['icon']['next'] = '';
$this->k_tai_conf['icon']['last'] = '';
$this->k_tai_conf['icon']['extLink'] = '';
$this->k_tai_conf['icon']['hTag'] = '';
$this->k_tai_conf['icon']['RSS'] = '';
$this->k_tai_conf['icon']['toMain'] = '';
// style
$this->k_tai_conf['style']['highlight'] = 'background-color:#ffc0cb';
// Easy login: 設定 or 解除リンクを表示するURI(XOOPS_URL以降)とuidのGETキーと挿入位置
$this->k_tai_conf['easyLoginConfPath'] = '/userinfo.php';
$this->k_tai_conf['easyLoginConfuid'] = 'uid';
$this->k_tai_conf['easyLoginConfInsert'] = 'content';
// GET query keys
$this->k_tai_conf['getKeys']['page'] = '_p_';
$this->k_tai_conf['getKeys']['hash'] = '_h_';
$this->k_tai_conf['getKeys']['block'] = '_b_';
//// Google Adsense 設定
// config ファイルのパス
$this->k_tai_conf['googleAdsense']['config'] = '';
// 挿入場所 ('header', 'body', 'footer') の下、無指定時はページ最上部
$this->k_tai_conf['googleAdsense']['below'] = '';
// Google Analytics 設定
$this->k_tai_conf['googleAnalyticsId'] = '';
// <a> タグの href 属性の書き換えルール
//$this->k_tai_conf['urlRewrites']['regex'][] = '';
//$this->k_tai_conf['urlRewrites']['tostr'][] = '';
// <img> タグの src 属性の書き換えルール
//$this->k_tai_conf['urlImgRewrites']['regex'][] = '';
//$this->k_tai_conf['urlImgRewrites']['tostr'][] = '';
// 携帯対応レンダー設定 以上
/////////////////////////////
$this->k_tai_conf の各設定は、サイトごとに行う必要がある場合がありますので、サイトごとの設定方法を説明します。
方法は、2種類あります。
この方法では、XOOPS_TRUST_PATH[9] 側 (XOOPS_TRUST_PATH[9]/class/hyp_common/preload/hyp_preload.conf.php) で各サイトごとに設定できます。
例えば、$this->k_tai_conf['disabledBlockIds'] の設定を (xoops[23].hypweb.net) に対して行いたい場合は、
1 |
|
のように設定します。(このサイトの設定例です)
※ trust側で設定する場合は、XOOPS_ROOT_PATH[12]/class/hyp_common/hyp_preload.conf.php を設置してはいけません。
各サイトの XOOPS_ROOT_PATH[12]/class/hyp_common に hyp_preload.conf.php に設置して設定を行います。
XOOPS_ROOT_PATH[12]/class/hyp_common/hyp_preload.conf.php を設置すると、XOOPS_TRUST_PATH[9]/class/hyp_common/preload/hyp_preload.conf.php は読み込まれなくなります。
ブロックは、サブメニューとしてタイトルを一覧表示するようになっています。
また、特定のブロックを常に表示したり、ブロックを無効にすることもできます。
特定のブロックを、メインコンテンツと共に常に表示することができます。
メインメニューやユーザーメニューは常に表示させておくと便利でしょう。
設定は、
// 常に表示するブロックの bid (Block Id) (メインメニューなど)
$this->k_tai_conf['showBlockIds'] = array();
で行います。
特定のブロックを無効にすることができます。
設定は、
// 非表示にするブロックの bid (Block Id)
$this->k_tai_conf['disabledBlockIds'] = array();
で行います。
ブロックの設定を行う場合は、その性格上、必ずサイトごとの設定で行う必要があります。
設定方法は、ブロックIDを配列で指定します。例えば、ブロックID 3, 5, 10 を非表示にしたい場合は、次のようになります。
// 非表示にするブロックの bid (Block Id)
$this->k_tai_conf['disabledBlockIds'] = array(3, 5, 10);
1 2 3 |
|
$this->k_tai_conf['googleAdsense']['config'] = 'xoops_trust_path[9]/class/hyp_common/ktairender/adsenseConf.php';
特定の HTML コメントを使って、コンテンツの部分的なコントロールが可能です。
各モジュールのテンプレート内でも、Smarty変数の Smarty変数の $smarty.const.HYP_K_TAI_RENDER を使って、場合分けができます。('===' とイコールが3つである必要があります)
部分的に場合分けしてもいいですし、大胆に全体を
<{if $smarty.const.HYP_K_TAI_RENDER === 2}> スマートフォン(jQuery mobile 使用時)の場合のテンプレート <{elseif $smarty.const.HYP_K_TAI_RENDER === 1}> 携帯の場合のテンプレート <{else}> PCの場合のテンプレート <{/if}>
とすることもできます。
d3forum では、スパム対策のデフォルトフィルターで、ゲスト投稿時に JavaScript を利用してフィルタリングを行っていますが、このフィルターが有効になっていると、ゲストが携帯で投稿することができません。
そこで、携帯からのアクセスかを IP 帯域で判断して、携帯であると判断した場合は、フィルタリングを行わないフィルターを書いてみました。
このファイルを、XOOPS_TRUST_PATH[9]/modules/d3forum/class にアップロードし、[ d3forum の管理画面 - 一般設定 - SPAM投稿チェック用クラス ] に 「default_ktai」と指定してください。
サーバーの PHP が PHP 4.3.0 未満、又は PHP 5 未満で Web サーバーが Apache でない場合、header('Location: ...') でリダイレクトしているところでセッションが切れてしまいます。ログイン状態であっても、そこでログアウトしてしまうということです。
可能であれば、HTTP Header を検査して Location であれば、セッションID付きURLに書き換えることでセッションが切れないようになっていますが、未対応の環境下ではそれを行うことができないので、携帯対応レンダラー側で対処することはできません。
未対応の環境下サーバーで、リダイレクト時にセッションが切れないようにする方法は以下の2つの方法があります。
例えば、
header('Location: ' . $url);
となっているところを次のように変更します。
if (defined('HYP_K_TAI_RENDER') && HYP_K_TAI_RENDER) {
redirect_header('Location: ' . $url);
} else {
header('Location: ' . $url);
}
if (defined('HYP_K_TAI_RENDER') && HYP_K_TAI_RENDER) {
$ktairender =& HypKTaiRender::getSingleton(); // リファレンス取得
$url = $HypKTaiRender->getRealUrl($url); // 相対URLなら絶対URLに変換 (要: Ver. 20090104 以降)
$url = $ktairender->addSID($url, XOOPS_URL); // セッションIDを付加
}
header('Location: ' . $url);
(This host) = https://xoops.hypweb.net