*colorプラグインの引数にセミコロン・コロンが記述できてしまう [#vcf98a63] -ページ: BugTrack -投稿者: [[reimy]] -優先順位: 重要 -状態: 完了 -カテゴリー: プラグイン -投稿日: 2003-08-28 (木) 01:13:07 -バージョン: **メッセージ [#n34cc2e7] colorプラグインの( )内の引数にセミコロンやコロンが記述できてしまうため、任意のCSSのプロパティと値を設定できてしまう。 colorプラグインの( )内の第1引数・第2引数の値にセミコロンやコロンを含む値が入ることはありえないので、修正すべき。コロンはともかく、セミコロンははじかないとまずい。 最近、colorプラグインのこのバグを利用してtext-alignを設定している例(たとえば[[official:自作プラグイン/navi2.inc.php]]や[[official:質問箱/216]]など)を散見するが、colorプラグインで出力されるタグはインライン要素の<span>~</span>であるため、不整合を引き起こしている(CSSのtext-alignプロパティはブロック要素にしか指定できない)。 ---- - style injectionとでも言いましょうか。サニタイズの必要がありますね。 -- [[ぱんだ]] &new{2003-08-28 (木) 09:34:40}; - htmlspecialchars()の代わりの関数を考えてみました。使えない文字を除去します。 -- [[ぱんだ]] &new{2003-08-28 (木) 10:15:56}; function plugin_color_sanitize($color) { return preg_replace('/[^\w#-]/','',$color); } -うまくいきました。きれいに除去できてます。&ref(color.inc.php); <li><span style="color:width100px">左寄せ</span><span style="color:width60text-alignright">右寄せ</span></li> <li><span style="color:width100px">次も左寄せ</span><span style="color:width60text-alignright">またまた右寄せ</span></li> ~-- [[reimy]] &new{2003-08-29 (金) 02:44:27}; -使えない文字が含まれている場合は<span>で囲まず、$bodyだけを返してしまうほうがいいかも。下記のように。PukiWiki-officialで実装してみました。 -- [[reimy]] &new{2003-08-29 (金) 03:00:03}; <li>左寄せ右寄せ</li> <li>次も左寄せまたまた右寄せ</li> -無効な文字を含む色名は、無効な文字を取り除いた後も無効である可能性が高い、と考えると、そのほうがいいかもしれません。そっちの線で行きますか。 -- [[ぱんだ]] &new{2003-09-03 (水) 10:09:55}; -cvsに投入しました。 [[cvs:plugin/color.inc.php]](v1.4:%%r1.6%%r1.7) -- [[ぱんだ]] &new{2003-09-03 (水) 10:32:30}; --これ、↓じゃないと意味ない気がします。 -- [[masao]] &new{2003-09-04 (木) 17:00:07}; function plugin_color_is_valid($color) { - return ($color == '') or preg_match('/^(#[0-9a-f]+|[\w-]+)/i',$color); + return ($color == '') or preg_match('/^(#[0-9a-f]+|[\w-]+)$/i',$color); } ---またやってしまった XD 修正しました。 [[cvs:plugin/color.inc.php]](v1.4:r1.8) -- [[ぱんだ]] &new{2003-09-05 (金) 09:19:25}; #comment //#comment