回答編集履歴

1

参考サイトを追加

2017/09/25 04:20

投稿

miyahan
miyahan

スコア3095

test CHANGED
@@ -2,7 +2,29 @@
2
2
 
3
3
 
4
4
 
5
+ * [PHPしか書けないザコがメールアドレス正規表現でガチ勢に挑んでみた - Qiita](https://qiita.com/mpyw/items/257eabe0b43b1e02e6f7)
6
+
7
+ * [この世の99%のEメールアドレスにマッチする正規表現、現る | 十円玉という名のブログ](https://www.10yendama.com/archives/1342)
8
+
9
+ * [そろそろメールアドレスを正規表現だけでチェックするのは終わりにしませんか? - Qiita](https://qiita.com/ShibuyaKosuke/items/0b9a8fddaefb2060a14a)
10
+
11
+ * [正規表現でのメールアドレスチェックは見直すべき – ReDoS | yohgaki's blog](https://blog.ohgaki.net/redos-must-review-mail-address-validation)
12
+
13
+
14
+
15
+ 特にPHP初級者が不完全な正規表現でメールアドレスのバリデーションをしている姿がしばしばバカにされるほどです。
16
+
17
+
18
+
19
+ * [404 Blog Not Found:「PHP使いはもう正規表現をblogに書くな」と言わせないでくれ](http://blog.livedoor.jp/dankogai/archives/51189905.html)
20
+
21
+ * [もうおまえらPHPerは正規表現をブログにうpするんじゃねえ! - noopな日々](http://d.hatena.ne.jp/noopable/20090320/1237511152)
22
+
23
+ * [さっきPHPerの正規表現を見たが、本当に唖然とした。Disりたい… - conflict error](http://webkit.seesaa.net/article/129745981.html)
24
+
25
+
26
+
5
- PHPには[検証フィルタ機能](http://jp2.php.net/manual/ja/filter.filters.validate.php)でさくっとチェックができるので、これを使うのが無難だと思います。
27
+ PHPには**[検証フィルタ機能](http://jp2.php.net/manual/ja/filter.filters.validate.php)でさくっとチェックができる**ので、これを使うのが無難だと思います。(これでも完璧なチェックは難しいと言われています)
6
28
 
7
29
 
8
30
 
@@ -11,3 +33,11 @@
11
33
  filter_var('hoge@example.com', FILTER_VALIDATE_EMAIL);
12
34
 
13
35
  ```
36
+
37
+
38
+
39
+ もちろん文字列のチェックだけではそのメールアドレスが有効かどうかの判定はできないので、最終的には様々なサイトがやっているように、実際に**確認メールを送ってそこの認証用URLにアクセスさせる**といった段取りが必要になってきます。
40
+
41
+
42
+
43
+ もう少し丁寧な実装では、確認メール送信前に**ドメインの有効性をチェック**をする場合もあるようです。