PHP에서 이메일을 검증하는 방법
php5를 사용하여 입력값이 유효한 이메일 주소인지 확인하려면 어떻게 해야 합니까?현재 이 코드를 사용하고 있습니다.
function isValidEmail($email){
$pattern = "^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,3})$";
if (eregi($pattern, $email)){
return true;
}
else {
return false;
}
}
단, 권장되지 않는 에러가 표시됩니다.이 문제를 해결하려면 어떻게 해야 하나요?제발 도와주세요.
.filter_var()
편리한 검증 및 검사 옵션을 많이 제공합니다.
filter_var($email, FILTER_VALIDATE_EMAIL)
PHP > = 5.2.0에서 사용 가능
기능에 의존하는 코드를 변경하지 않으려면 다음 작업을 수행합니다.
function isValidEmail($email){
return filter_var($email, FILTER_VALIDATE_EMAIL) !== false;
}
주의: 기타 용도(Regex가 필요한 경우)에서는 권장되지 않습니다.ereg
패밀리 Functions는 POSIX Regex Functions(POSIX Regex Functions)로.preg
패밀리(PCRE Regex 함수)약간의 차이가 있으므로 매뉴얼을 읽으면 충분합니다.
PHP 5.3.3 및 5.2.14에는 FILTER_VALIDATE_EMAIL과 관련된 버그가 있어 큰 값을 검증할 때 segfault가 발생하였습니다.이를 위한 간단하고 안전한 회피책은 다음과 같습니다.
strlen()
전에filter_var()
최종 버전은 5을 받은 .5.3.4의 경우, 5.3.4의 경우, 5.3.4의 경우, 5.3.4의 경우, 5.3.4의 경우입니다.
이 버그는 이미 수정되었습니다.
업데이트 2: 이 방법은 물론 검증됩니다.bazmega@kapa
유효한 전자 메일 주소입니다.사실 유효한 전자 메일 주소이기 때문입니다..「 「 」 「 」 「 」bazmega@kapa.com
이 블로그 투고(@Istiaque Ahmed가 게시한 링크)에서 제안하는 바와 같이 증강할 수 있습니다.filter_var()
도메인 부분에 점이 있는지 확인하는 정규식을 사용합니다(단, 유효한 TLD는 확인하지 않습니다).
function isValidEmail($email) {
return filter_var($email, FILTER_VALIDATE_EMAIL)
&& preg_match('/@.+\./', $email);
}
@Eliseo Ocampos가 지적했듯이 이 문제는 PHP 5.3 이전 버전에만 존재합니다.그 버전에서는 regex가 변경되어 이제 이 체크가 이루어지기 때문에 당신은 그럴 필요가 없습니다.
http://www.php.net/manual/en/function.ereg.php 의 주의사항을 참조해 주세요.
Note:
PHP 5.3.0에서는 regex 확장이 PCRE 확장에 적합하도록 권장되지 않습니다.이 함수를 호출하면 E_DEPRECATED 알림이 발행됩니다.PCRE 로의 변환에 관한 도움말에 대해서는, 차이점 리스트를 참조해 주세요.
Note:
preg_match()는 Perl 호환 정규 표현 구문을 사용합니다.이 구문은 대부분의 경우 ereg()의 대체 수단입니다.
이것은 오래된 게시물이지만, 지금까지 아무도 한 가지 문제를 언급하지 않았기 때문에 저는 저의 해결책을 공유하겠습니다.
새 이메일 주소에는 UTF-8 문자 또는 다음과 같은 특수 도메인 이름을 포함할 수 있습니다..live
,.news
기타.
또한 일부 이메일 주소는 Cyrilic과 모든 경우에 표준 regex 또는 또는filter_var()
실패합니다.
그래서 내가 해결책을 만든 거야
function valid_email($email)
{
if(is_array($email) || is_numeric($email) || is_bool($email) || is_float($email) || is_file($email) || is_dir($email) || is_int($email))
return false;
else
{
$email=trim(strtolower($email));
if(filter_var($email, FILTER_VALIDATE_EMAIL)!==false) return $email;
else
{
$pattern = '/^(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){255,})(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){65,}@)(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22))(?:\\.(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22)))*@(?:(?:(?!.*[^.]{64,})(?:(?:(?:xn--)?[a-z0-9]+(?:-+[a-z0-9]+)*\\.){1,126}){1,}(?:(?:[a-z][a-z0-9]*)|(?:(?:xn--)[a-z0-9]+))(?:-+[a-z0-9]+)*)|(?:\\[(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){7})|(?:(?!(?:.*[a-f0-9][:\\]]){7,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?)))|(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){5}:)|(?:(?!(?:.*[a-f0-9]:){5,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3}:)?)))?(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))(?:\\.(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))){3}))\\]))$/iD';
return (preg_match($pattern, $email) === 1) ? $email : false;
}
}
}
이 기능은 모든 케이스와 이메일 형식에 대해 완벽하게 작동합니다.
항상 이걸 쓰고 있어요.
function validEmail($email){
// First, we check that there's one @ symbol, and that the lengths are right
if (!preg_match("/^[^@]{1,64}@[^@]{1,255}$/", $email)) {
// Email invalid because wrong number of characters in one section, or wrong number of @ symbols.
return false;
}
// Split it into sections to make life easier
$email_array = explode("@", $email);
$local_array = explode(".", $email_array[0]);
for ($i = 0; $i < sizeof($local_array); $i++) {
if (!preg_match("/^(([A-Za-z0-9!#$%&'*+\/=?^_`{|}~-][A-Za-z0-9!#$%&'*+\/=?^_`{|}~\.-]{0,63})|(\"[^(\\|\")]{0,62}\"))$/", $local_array[$i])) {
return false;
}
}
if (!preg_match("/^\[?[0-9\.]+\]?$/", $email_array[1])) { // Check if domain is IP. If not, it should be valid domain name
$domain_array = explode(".", $email_array[1]);
if (sizeof($domain_array) < 2) {
return false; // Not enough parts to domain
}
for ($i = 0; $i < sizeof($domain_array); $i++) {
if (!preg_match("/^(([A-Za-z0-9][A-Za-z0-9-]{0,61}[A-Za-z0-9])|([A-Za-z0-9]+))$/", $domain_array[$i])) {
return false;
}
}
}
return true;
}
사용자 데이터는 우수한 개발자에게 매우 중요하므로 동일한 데이터를 계속 요청하지 말고 몇 가지 논리를 사용하여 데이터의 기본 오류를 수정하십시오.
이메일 확인 전:먼저 이메일에서 모든 불법 문자를 제거해야 합니다.
//This will Remove all illegal characters from email
$email = filter_var($email, FILTER_SANITIZE_EMAIL);
그 후, 이것을 사용해 전자 메일 주소를 검증합니다.filter_var()
기능.
filter_var($email, FILTER_VALIDATE_EMAIL)) // To Validate the email
예를 들어,
<?php
$email = "john.doe@example.com";
// Remove all illegal characters from email
$email = filter_var($email, FILTER_SANITIZE_EMAIL);
// Validate email
if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
echo $email." is a valid email address";
} else {
echo $email." is not a valid email address";
}
?>
용도:
- 또는 http://php.net/manual/en/function.filter-var.php에서 "filter_var"로 지정합니다.
var_dump(filter_var('bob@example.com', FILTER_VALIDATE_EMAIL));
- 또는 https://github.com/egulias/EmailValidator의 "Email Validator"를 참조하십시오.
$validator = new EmailValidator();
$multipleValidations = new MultipleValidationWithAnd([
new RFCValidation(),
new DNSCheckValidation()
]);
$validator->isValid("example@example.com", $multipleValidations); //true
iasd@x.z-----------------------------------------------------------------------------------------------------------------------------------------------------------------
e-메일의 유효성을 확인하기 위해 다음 기능을 사용합니다.
function correcorre($s){// correo correcto
$x = '^([[:alnum:]](_|-|\.)*)*[[:alnum:]]+@([[:alnum:]]+(-|\.)+)*[[:alnum:]]+\.[[:alnum:]]+$';
preg_match("!$x!i", $s, $M);
if(!empty($M[0]))return($M[0]);
}
더 발전하고 공유해주세요, 감사합니다.
언급URL : https://stackoverflow.com/questions/5855811/how-to-validate-an-email-in-php
'programing' 카테고리의 다른 글
MySQL 오류 #1133 - 사용자 테이블에서 일치하는 행을 찾을 수 없습니다. (0) | 2022.11.04 |
---|---|
파손된 xampp 'mysql.user' 테이블 복구 방법 (0) | 2022.11.04 |
왜 java.util일까요?선택사항은 Serialable이 아닙니다. 이러한 필드를 사용하여 개체를 Serialize하는 방법 (0) | 2022.11.04 |
여러 OR 조건이 있는 ZF2 원칙 쿼리 (0) | 2022.11.04 |
PHP용 예쁜 프린트가 있나요? (0) | 2022.11.04 |