現在、掲示板をPHPで作っています。
入力された文字列の無効化と許可タグの分別に正規表現を使いたいと考えております。
そこで、現状では、まずすべての < > を特殊文字に変換し、その後に、許可タグ(属性)のタグを < > にもどそうとしています。
たとえば、fontタグならcolorとsizeを許可しようとして、次のような正規表現を作ってみましたが、うまくいきません。
/<font((( )*(color=)[\"\']?.{1,7}[\"\']?)|(( )*(size=)[\"\']?.{1,2}[\"\']?))*>/i
正規表現はまだ勉強し始めたところで、おかしなところだらけだと思いますが、何かヒントだけでもいただけたらと思います。
どうぞよろしくお願いします。
No.1ベストアンサー
- 回答日時:
$extention[] = "/<(font(?:(?: color=[\"\']?(?:")?[#0-9a-z]{1,20}[\"\']?(?:")?)?|(?: size=[\"\']?(?:")?[\d]{1,2}[\"\']?(?:")?)?)*)>/i";
$extention[] = "#<(/font)>#i";
foreach($extention as $ext){
$tag = preg_replace($ext,"<$1>",$tag);
}
こんなのはどうでしょうか。
多分" や 'が"になってるんじゃないかな?と思います。
勘ですが。
お礼が遅くなってしまい申し訳ございませんでした。
ご教示いただいたとおり試してみますと、キッチリしていした属性の時のみ処理できるようになりました。
しかし、下記のように
$tag = "<font size=10 color='red'>テスト</font>";
$tag = str_replace(array("<",">"),array("/<",">#i"),$tag);
foreach($extention as $ext){
$tag = preg_replace($ext,"<$1>",$tag);
}
print $tag;
とすると、結果が
/<font size=10 color='red'>#iテスト/</font>#i
と、タグの前後に / #i がついてしまうのです。
勉強不足で試行錯誤を繰り返しているのですが、
2つ目の正規表現のデリミタ部分にある # は何を表しているのでしょうか?
これを / に変えるとエラーとなってしまいます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP htmlspecialcharsが機能していないです。 バグですか? 1 2022/04/05 01:22
- JavaScript フォームが空欄の時にフォームの外をクリックすると、エラーが出るコードを調べています。 1 2023/06/25 11:51
- PHP if(preg_match("/[^0-9]/",$gu_d)){意味を教えてください。 1 2022/05/06 05:37
- Visual Basic(VBA) VBAにてメール作成した際、一部指定箇所のみ赤文字にしたいです。 下記の内容ですと作成されたメール本 1 2022/04/27 13:31
- HTML・CSS アコーディオンメニューが思うように動作しません。 1 2023/08/20 16:48
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- HTML・CSS スマホ表示用のwebページ、style.cssでは表の中の文字 font-size は指定できない? 1 2023/03/27 18:57
- WordPress(ワードプレス) ワードプレスで、投稿一覧ページにタグを表示する方法 投稿につけたタグを、記事一覧ページにもカテゴリと 1 2023/05/10 21:41
- その他(学校・勉強) この中で間違ってある説明はありますか?詳しい方に教えていただきたいです。 A. 1つのプログラムが複 2 2023/07/14 01:15
- オープンソース csvデータのダブルクォーテーションで囲まれた文字内にあるカンマを削除したい 3 2022/09/02 15:17
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
JSFタグのfタグとは
-
reuterの記事をbeautiful.soup....
-
htmlspecialchars関数を使いな...
-
★PHP★フォーム登録時にタグを読...
-
VBAのコマンドボタンの文字列の...
-
ソースコードの1行が長いとき...
-
エスケープ文字の復帰(¥r)と...
-
データベースから取り出したテ...
-
改行について
-
エクセルのCOUNTIFが正しくカウ...
-
ファイルから読み取った改行文...
-
VBScriptである文字列に半角文...
-
メッセージボックスで1025文字...
-
半角記号、全角記号を含む正規...
-
Excel関数「COUNTIF」で”文字”...
-
数値をASCII文字にする方法につ...
-
文字の入力で横バー上段、中断...
-
COBOLの改行
-
文字列の置換をCStringで(C++)
-
Excel2002 一桁数字だけ全角に置換
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
reuterの記事をbeautiful.soup....
-
正規表現で複数行に渡る範囲を...
-
変数にHTMLを代入する場合
-
javascriptの正規表現でhtmlか...
-
タグにはさまれている文字以外...
-
VBSでのhtmlタグ要素名の置換
-
objective-cでのHTMLタグ表示に...
-
phpの正規表現でstyle="●●"を削...
-
Strutsでリンクを動的に生成したい
-
PHPスクレイピングが上手くいき...
-
htmlのソースからテーブルの値...
-
JSFタグのfタグとは
-
ASP.NET(C#)とhtmlの#include
-
あるタグから対応するタグまで...
-
preg_replaceでの正規表現によ...
-
eclipseより、タスク・タグの使...
-
HTMLファイルの書き換え
-
Nvuで作成したhtmlをコピペして...
-
htmlタグ間の特定文字置換
-
[正規表現][入れ子]ネストされ...
おすすめ情報