PHPで携帯とPC用のサイトを作成しています。

会員入会処理があるのでパスワードを入力させているのですが、半角英数字以外の入力に対してエラーを返すため、以下の処理を行っています。

if( !(mb_ereg(’[^0-9a-zA-Z]’, $_POST[’newpassword’])) )
{
error( ”パスワードにひらがな・カタカナ・漢字・記号が含まれている可能性があります。” );
exit();
}

しかし実際テストしてみるとこのチェックに引っかかりません。
入力時、パスワード欄(input type=”password”)に「あ」と入力するとアスタリスクが2個表示されるところを見ると、1バイトずつに分解してデータを受け取っているような気がします。
また、AUなどでは「input type=”password”」が無効になっているんでしょうか…
どうぞよろしく。

回答の条件
  • URL必須
  • 1人2回まで
  • 登録:2005/12/31 20:20:16
  • 終了:--

回答(4件)

id:elf No.1

えるふん回答回数76ベストアンサー獲得回数82005/12/25 03:12:42

ポイント20pt

http://php.net/mbstring

PHP: マルチバイト文字列関数(mbstring) - Manual

正規表現が「0-9a-zA-Z*以外*」,if文条件が「ではない(not)になっているため,

「0-9a-zA-Z」の場合は条件を実行という風になっています.


if( !(mb_ereg(’[0-9a-zA-Z]’, $_POST[’newpassword’])) )

if( (mb_ereg(’[^0-9a-zA-Z]’, $_POST[’newpassword’])) )

でしょう.

id:esecua No.2

esecua回答回数510ベストアンサー獲得回数102005/12/25 13:11:34

ポイント20pt

if(!ereg(”^([0-9a-zA-Z])”, $_POST[’newpassword’])){

//エラー処理


かなぁ?間違っていたらごめんなさい。

id:insidekick No.3

insidekick回答回数7ベストアンサー獲得回数02005/12/26 09:09:53

ポイント20pt

if (!preg_match(”/^[a-zA-Z0-9]+$/”, $_POST[’newpassword’])) {

エラー処理

}


でどうでしょうか?

id:kouuok

ありがとうございました。

もうちょい考えて見ます。

2005/12/26 20:47:15
id:tomocky1 No.4

tomocky1回答回数16ベストアンサー獲得回数02005/12/31 22:09:37

ポイント20pt

PCで行った場合、


<?php

if (mb_ereg(”[0-9a-zA-Z]”, $_POST[”newpassword”])) {

print(”Check OK”);

} else {

print(”Check False”);

}

?>


以上のようなスクリプトで振り分けることができました。

(参考:mbstringの値は、

mbstring.detect_order no value no value

mbstring.encoding_translation Off Off

mbstring.func_overload 0 0

mbstring.http_input pass pass

mbstring.http_output pass pass

mbstring.internal_encoding no value no value

mbstring.language neutral neutral

mbstring.substitute_character no value no value

でデフォルトのままです。)


気になる点は、上記でも述べられていた、”!”がある点と、

”’”が大文字になっている点ですが、プログラム自体はあっていると思います。


あとは、携帯での都合ですが(PCの”type=password”では、ひらがなも一文字です)

一言にAUといっても、XHTML or HDML と二種類あって、機種によってはHTMLは自動的に

HDMLに変換されたりもします。

同じ会社でも古い機種と新しい機種で違うので調べてみてください。

参考までに、AUのEZwebのサイトを載せておきます。

http://www.au.kddi.com/ezfactory/tec/spec/html_con003_2.html#pas...

KDDI au: 入力フォーム変換仕様 > <input type="password">/<input type="radio">/<input type="checkbox">

コメントはまだありません

この質問への反応(ブックマークコメント)

「あの人に答えてほしい」「この質問はあの人が答えられそう」というときに、回答リクエストを送ってみてましょう。

これ以上回答リクエストを送信することはできません。制限について

絞り込み :
はてなココの「ともだち」を表示します。
回答リクエストを送信したユーザーはいません