回答編集履歴

3

見直し

2019/06/18 14:18

投稿

退会済みユーザー
test CHANGED
@@ -1,12 +1,36 @@
1
- 忙しいんで中身も読まずに回答しますけども。
1
+ 忙しいんで中身も読まずに、追加情報もないまま回答しますけども。
2
2
 
3
3
 
4
4
 
5
- submit.phpにおいても入力データの検証は必要ですが、
5
+ input.php
6
6
 
7
- の前段階confirm.phpにおいてまず入力データの検証をしてエラー情報を表示するようにします
7
+ →入力フォーム表示、及び送信前の軽微な入力エラーチェック処理(はjavascriptで)
8
8
 
9
+
10
+
11
+ confirm.php
12
+
13
+ →入力データの検証、データベースに照会して判定する入力エラーチェック処理。
14
+
15
+ エラーが有る場合にinput.phpに差し戻して、
16
+
17
+ エラー情報はinput.phpにて表示できるようにする。
18
+
19
+
20
+
21
+ submit.php
22
+
23
+ →入力データの再検証(必ずしもconfirm.phpからのみ受信するわけではないので)、データベース登録処理。
24
+
25
+ この時点ではエラーは殆どないものとして、ただしconfirm.phpからsubmit.phpに至るまでに時間が経過して
26
+
27
+ 条件が不成立する場合なども想定した、confirm.phpと同等以上の入力データの再検証が必要なはず。
28
+
9
- confirm.phpからsubmit.phpに進めるのは、入力データに不備がなく登録できる条件が成立しているときのみ、とします。
29
+ confirm.phpからsubmit.phpに進めるのは、入力データに不備がなく登録できる条件が(その時点で)成立しているときのみ、とします。
30
+
31
+
32
+
33
+ ・・っていうのが王道な処理の流れではないかと。
10
34
 
11
35
 
12
36
 

2

加筆修正

2019/06/18 14:18

投稿

退会済みユーザー
test CHANGED
@@ -63,3 +63,19 @@
63
63
  にしてみたりとか、パターンを工夫すれば済む話です。
64
64
 
65
65
  (この例はあくまで例示なので、想定する入力データを十分検討の上正規表現パターンを実装してください。)
66
+
67
+
68
+
69
+ よりユーザー体験を良くするには、input.phpで送信ボタンをクリックした際に
70
+
71
+ かるく入力データのチェックをjavascript上でやってその場でエラーメッセージ表示することも
72
+
73
+ ご検討ください。
74
+
75
+ チェックできるのは入力文字種、長さくらいかもしれませんが。
76
+
77
+ データベースに照会しないと判明しないエラーはphp側でやっていいと思います。
78
+
79
+ 軽微な入力エラーならjavascriptで判定して送信前にエラー表示されると
80
+
81
+ ユーザーに係る負担は軽減されます。

1

加筆修正

2019/06/18 12:43

投稿

退会済みユーザー
test CHANGED
@@ -31,3 +31,35 @@
31
31
  「こうなっていないものは全部拒否」という、通るパターンを検証するのであれば、
32
32
 
33
33
  一つや二つの正規表現パターンで済ませられます。
34
+
35
+ 具体例をあげると、
36
+
37
+ 例えば電話番号をどう入力させますか。
38
+
39
+ 市外局番からすべての桁を入力させるのでしょうけど、
40
+
41
+ 携帯電話の番号というのもありますし、
42
+
43
+ ハイフンを入れる入れない、カッコを付けるつけない、国番号をつけるつけない、
44
+
45
+ など条件がいろいろ考えられます。
46
+
47
+ 入力のしやすさを考慮して「記号なしに数字のみ、市外局番から」とした場合、
48
+
49
+ /^[0-9]+$/
50
+
51
+ っていうパターンさえ通ればOKとなります。
52
+
53
+ いちいちカッコが入っていないかどうかを検証したり、
54
+
55
+ ハイフンが入っていないかを検証したり
56
+
57
+ 空白が入っていないかを検証したりしなくてよいのです。
58
+
59
+ より正確性を期するなら、先頭の数字はゼロであることを強制するために
60
+
61
+ /^0[0-9]+$/
62
+
63
+ にしてみたりとか、パターンを工夫すれば済む話です。
64
+
65
+ (この例はあくまで例示なので、想定する入力データを十分検討の上正規表現パターンを実装してください。)