にしし ふぁくとりー:西村文宏 個人サイト

Presented by Nishishi via Movable Type. Last Updated: 2022/03/25. 10:39:27.

正規表現での句読点と英字A・Bの関係

以前、スパム投稿(コメントスパム)対策として、正規表現で句読点の有無をチェックすれば良いという提案をしたことがありました。以下のよーな正規表現を書く方法です。(Perl)

if ( $comment !~ m/[、。]/ ) { エラー処理 }

これを使えば、英文だけの投稿をブロックできるだろう…ということなんですけど、穴があることに気づきました。^^;;;

SHIFT-JISコードでは、読点「、」のコードは「81,41」、句点「。」のコードは「81,42」なんですよね。ASCIIコードでは、大文字のAが「41」、Bが「42」です。
なので、上記の正規表現で(2バイト文字を1バイトずつ分解して解釈しちゃう場合は)、アルファベットの大文字「A」と「B」もマッチしちゃうのですねー。(^_^;)
ううーん。

EUCコードの場合は、読点「A1,A2」・句点「A1,A3」になりますし、UTF-8コードの場合は、読点「E3,80,81」・句点「E3,80,82」になるので、アルファベットとはマッチしないのですが。

ソースがSHIFT-JISの場合は、「A」と「B」だけ容認しちゃうことになる(可能性がある)ので注意が必要ですね。まあ、スパム投稿の英文に大文字の「A」や「B」が含まれる可能性は、そんなに高くない気がするので、あんまり問題にはならないかも知れませんが。^^;

--- (追記) ---
前言撤回。(^_^;) スパム投稿を調べると、「All」とか「But」で始まる英文も結構あるようでした。
ぐぬぅ。

コメント

コメント数: 0件

コメント投稿欄 この日記に対するコメント投稿を歓迎します。



※本文中にURLは書けません。(書くと投稿が拒否されますのでご注意下さい。)

※ご投稿頂いた内容は、掲載前に管理者が確認する設定にしている場合があります。たいていは数日以内には表示されるはずですので、気長にお待ち願います。m(_ _)m

著者紹介


にしし(西村文宏)

にししでございます。本書いたり記事書いたりしてます。あと萌えたり。著書5冊発売中です(Web製作系4冊+小説1冊)。著書や記事は「西村文宏」名義。記事は主にAll Aboutで連載。本の最新刊は2011年3月に発売されたライトノベルでございますよ。

Twitter:にしし/西村文宏
にしし/西村文宏 on facebook にしし/西村文宏 on mixi フォローはお気軽に!

にしし(西村文宏)連絡先
☕ コーヒーをおごる

著書一覧と詳細

にししふぁくとりー Sakura scope内限定での主要なカテゴリ

--- 当サイト内を検索 ---