PHP에는 이메일 주소를 확인하는 방법이 함께 제공됩니다.

*文
풀어 주다: 2023-03-18 18:58:01
원래의
2283명이 탐색했습니다.

이 글에서는 메일함이 존재하는지 확인하는 PHP만의 방법과, URL과 IP가 합법적인지 확인하는 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) 1@a.com
로그인 후 복사

불법 이메일 형식 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를 사용하면 확실히 실패하며 나머지는

checkdnsrr을 사용하여 추가로 판단할 수 있습니다.


$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 기능을 사용하는 것입니다.

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

PHP 필터

예제 #1 A filter_var() example


<?php
var_dump(filter_var(&#39;bob@example.com&#39;, FILTER_VALIDATE_EMAIL));
var_dump(filter_var(&#39;http://example.com&#39;, FILTER_VALIDATE_URL, FILTER_FLAG_PATH_REQUIRED));
?>
로그인 후 복사

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


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

관련 권장 사항:

php 번호 확인 홀수 또는 짝수인 코드

php 파일이나 디렉토리가 존재하는지 확인 코드 요약

PHP 정규식의 기본 및 간단한 예

위 내용은 PHP에는 이메일 주소를 확인하는 방법이 함께 제공됩니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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