PHP에는 이메일 주소가 존재하는지 확인하는 자체 방법이 있습니다._php 팁

WBOY
풀어 주다: 2016-05-16 19:59:18
원래의
1550명이 탐색했습니다.

PHP에서 이메일 주소를 확인하는 방법은 여러 가지가 있습니다. 가장 일반적으로 사용되는 방법은 정규식을 직접 작성하는 것입니다. 그러나 정규식은 PHP만의 확인 방법이 있습니다.

filter_var

filter_var는 PHP에 내장된 변수 필터링 방법으로 정수, 부동 소수점 숫자, 이메일 주소, URL, MAC 주소 등을 확인하는 데 사용할 수 있는 다양한 실용적인 필터를 제공합니다.

filter_var가 false를 반환하면 변수가 필터를 통과할 수 없다는 의미이며 이는 불법이라는 의미입니다.

$email = "lastchiliarch@163.com";
 
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
 
 
$email = "asb";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
 
$email = "1@a.com";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
로그인 후 복사

출력:

string(21) "lastchiliarch@163.com"
bool(false)
string(7) <a href="mailto:1@a.com">1@a.com</a>
로그인 후 복사

불법 이메일 형식 asb의 경우 false를 반환하지만 1@a.com의 경우 통과하지만 여전히 약간의 결함이 있습니다.

그러나 일반 규칙을 통과하면 1@a.com이 합법적인 이메일 주소로 간주됩니다. 그렇다면 이를 보다 정확하게 확인할 수 있는 방법은 없을까요?

checkdnsrr

checkdnsrr은 실제로 지정된 호스트의 DNS 레코드를 쿼리하는 데 사용되며 사서함이 존재하는지 확인하는 데 사용할 수 있습니다.

1@a.com의 경우 MX 레코드가 존재하지 않아야 합니다.

$email = "lastchiliarch@163.com";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
  $email = "1@a.com";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
로그인 후 복사

출력:

  bool(true)
  bool(false)
로그인 후 복사

보시다시피 완벽합니다. 유일한 단점은 결국 네트워크 요청입니다. 따라서 이 방법을 사용하여 동시에 많은 수의 사서함을 확인하는 것은 적합하지 않습니다.

filter_var checkdnsrr

확인을 위해 filter_var과 checkdnsrr을 결합할 수 있습니다. 대부분의 불법 메일함은 filter_var을 사용하면 확실히 실패하고 나머지는 사용할 수 있습니다

추가 판단을 위해 dnsrr을 확인하세요.

$email_arr = array("lastchiliarch@163.com", "1@a.com");
  foreach($email_arr as $email) {
    if (filter_var($email) === false) {
      echo "invalid email: $email \n";
      continue;
    }
 
    if(checkdnsrr(array_pop(explode("@",$email)),"MX") === false) {
      echo "invalid email: $email \n";
      continue;
    }
  }
 
로그인 후 복사

출력:

invalid email: 1@a.com
로그인 후 복사

그러나 MX 레코드만 확인하기 때문에 163.com이 존재하는지 확인할 수 있을 뿐 사용자 lastchiliarch가 존재한다는 것을 증명할 수는 없다는 점에 유의해야 합니다.

메일함의 존재를 보다 정확하게 확인하고 싶다면 SMTP 서버에 접속해서만 확인하면 됩니다.

이메일 확인 방법을 도입했습니다. 이메일, URL, IP가 합법적인지 확인하는 방법은 다음과 같습니다.

가장 중요한 것은 filter_var 함수를 사용하는 것입니다.

문법
filter_var(변수, 필터, 옵션)
변수가 필요합니다. 필터링할 변수를 지정합니다.
필터는 선택사항입니다. 사용할 필터의 ID를 지정합니다.
옵션은 플래그/옵션을 포함하는 배열을 지정합니다. 각 필터에 대해 가능한 플래그와 옵션을 확인하세요.

PHP 필터

예제 #1 filter_var() 예

<&#63;php

var_dump(filter_var('bob@example.com', FILTER_VALIDATE_EMAIL));

var_dump(filter_var('http://example.com', FILTER_VALIDATE_URL, FILTER_FLAG_PATH_REQUIRED));

&#63;>

로그인 후 복사

위 루틴은 다음을 출력합니다:

string(15) "bob@example.com"
bool(false)
로그인 후 복사

위 내용은 이 글의 전체 내용입니다. PHP 이메일 확인에 도움이 되셨으면 좋겠습니다.

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿