質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
セキュリティー

このタグは、コンピューターシステムの安全性やデータの機密性に関連したトピックの為に使われます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

バリデーション

Validationとは特定の入力データが、求められた条件に当てまっているかをチェックするために使われます。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Q&A

解決済

2回答

1467閲覧

PHPで入力値のバリデーションを行う時の順番はどっち?

nako01

総合スコア37

セキュリティー

このタグは、コンピューターシステムの安全性やデータの機密性に関連したトピックの為に使われます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

バリデーション

Validationとは特定の入力データが、求められた条件に当てまっているかをチェックするために使われます。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

0グッド

1クリップ

投稿2020/06/17 06:17

編集2020/06/17 06:19

#解決したい事
PHPで入力値のバリデーションを行う時、文字種と文字数どちらを先にチェックするべきでしょう?

php

1if (!empty($data['username']) && !empty($data['password'])) { 2 // ユーザー名のバリデーション 3 if (preg_match("/[^0-9a-zA-Z]+/", $data["username"])) { 4 $errors[] = 'ユーザー名:2~8文字の半角英数字で入力してください'; 5 } elseif (2 > strlen($data["username"]) || strlen($data["username"]) > 8) { 6 $errors[] = 'ユーザー名:2~8文字の半角英数字で入力してください'; 7 } 8}

個人的には、文字種、文字数どちらが先でも変わらないを思っているのですが、ネットで調べていても意見が別れています。

#####文字種が先の人の意見:
・スクリプト的なものを入れ込まれた際に以降の処理を行わないようになるべく早めに入力値の文字種チェックは行いたい。
・strlen()を使っているので全角だと1文字を2文字以上でカウントしてしまうので文字数オーバーのエラーが出て「???」っていう可能性があるので、先に文字種。

#####文字数、文字種どちらが先でもいい人の意見:
・バリデーションは、処理自体は不正な入力値を判別する箇所で、不正なものを実行されたり、データに入れ込まれたりするところではないので、別に順番はそんなに気にしなくても良い。
・スクリプトに関しても、文字数を制限することで攻撃から身を守る手段になるはず。

順番は何が一番正しいのでしょうか。
理由も含めてご教授お願い出来ないでしょうか。。!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

文字種と文字数どちらを先にチェックするべきでしょう?

「一気にチェックする」という選択肢はないのでしょうか。

php

1if (!preg_match("/^[0-9a-zA-Z]{2,8}\z/", $data["username"])) {

投稿2020/06/17 06:21

編集2020/06/17 06:22
maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nako01

2020/06/17 06:59

!!頂いたアドバイスで実装してみたら出来ました! お勉強になりましたmmありがとうございます!
guest

0

ついでに、、頂いたアドバイスを元に、セキュリティ面考慮すると

php

1if (!preg_match("/\A[0-9a-zA-Z]{2,8}\z/", $data["username"])) {

^\Aにしました!

参考記事:https://qiita.com/suin/items/2b9376ddd14a7fb40759

投稿2020/06/17 07:02

nako01

総合スコア37

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問