정규 표현식을 사용하여 이메일 주소/이메일 주소 필터링
이번에는 정규식을 사용하여 이메일 사서함/이메일 주소를 필터링하고 정규식을 사용하여 이메일 사서함/이메일 주소를 필터링할 때 몇 가지 주의사항을 알려드리겠습니다. 아래는 실제 사례입니다. 살펴보겠습니다.
사용자 등록을 할 때 이메일/이메일 주소에 대한 정규 표현식이 자주 사용됩니다. 이 글에서는 프로젝트 상황에 따라 가장 적합한 솔루션을 선택할 수 있습니다
간단히
사용자를 등록할 때 이메일/이메일 주소에 대한 정규 표현식이 자주 사용됩니다. 이 문서에서는 프로젝트 상황에 따라 가장 적합한 옵션을 선택할 수 있습니다.
옵션 1(공통 사용)
규칙은 다음과 같이 정의됩니다.
대문자[A-Z], 소문자[a-z], 숫자[0-9], 밑줄[_]을 사용합니다. , 빼기 기호 [-]와 마침표[.]로 시작하며 [+]를 한 번 이상 반복해야 합니다.
중간에 @ 기호를 포함해야 합니다.
@ 뒤에는 대문자[A-Z], 소문자[a-z], 숫자[0-9], 밑줄[_], 빼기 기호[-], 마침표[.]가 와야 하며 반복되어야 합니다. 대부분 한 번 [+].
끝은 2~4자리의 대문자와 소문자 [A-Za-z]{2,4}를 연결하는 마침표[.]여야 합니다.
위 규칙을 사용하여 다음 정규식을 제공합니다.
var pattern = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;
완전한 테스트 코드
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title>邮箱/邮件地址的正则表达式及分析(JavaScript,email,regex)</title> </head> <body> <p id="main"></p> <script> var pattern = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/; w("pattern.test('cn42du@163.com') = "+pattern.test('cn42du@163.com')+";"); w("pattern.test('ifat3@sina.com.cn') = "+pattern.test('ifat3@sina.com.cn')+";"); w("pattern.test('ifat3.it@163.com') = "+pattern.test('ifat3.it@163.com')+";"); w("pattern.test('ifat3_-.@42du.cn') = "+pattern.test('ifat3_-.@42du.cn')+";"); w("pattern.test('ifat3@42du.online') = "+pattern.test('ifat3@42du.online')+";"); w("pattern.test('毛三胖@42du.cn') = "+pattern.test('毛三胖@42du.cn')+";"); function w(val) { document.getElementById("main").innerHTML += val +"<br />"; } </script> </body> </html>
테스트 결과:
pattern.test('cn42du@163.com') = true; pattern.test('ifat3@sina.com.cn') = true; pattern.test('ifat3.it@163.com') = true; pattern.test('ifat3_-.@42du.cn') = true; pattern.test('ifat3@42du.online') = false; pattern.test('毛三胖@42du.cn') = false; pattern.test('cn42du@163.com') = true; pattern.test('ifat3@sina.com.cn') = true; pattern.test('ifat3.it@163.com') = true; pattern.test('ifat3_-.@42du.cn') = true; pattern.test('ifat3@42du.online') = false; pattern.test('毛三胖@42du.cn') = false;
구성표 1의 설명
구성표 1은 가장 일반적으로 사용되는 이메일 정규식 확인 구성표입니다. , 또한 대부분의 애플리케이션 시나리오에 적합합니다. 위 테스트에서 볼 수 있듯이 이 표현식은 .online 및 .store로 끝나는 도메인 이름을 지원하지 않습니다. 이러한 유형의 도메인 이름(4자리 이상)과 호환되어야 하는 경우 정규식 {2,4} 끝의 제한 부분을 조정하면 됩니다(예: {2,8}). 또 다른 문제는 이메일 사용자 이름에 중국어 문자가 포함될 수 없다는 것입니다.
옵션 2(개정 옵션 1)
규칙이 다음과 같이 추가됩니다.
사용자 이름에는 중국어 [u4e00-u9fa5]를 포함할 수 있습니다.
도메인 이름은 최대 8자리로 끝날 수 있습니다. 2,8}
업데이트된 정규식은 다음과 같습니다.
var pattern = /^([A-Za-z0-9_\-\.\u4e00-\u9fa5])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,8})$/;
전체 테스트 코드
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title>邮箱/邮件地址的正则表达式及分析(JavaScript,email,regex)</title> </head> <body> <p id="main"></p> <script> var pattern = /^([A-Za-z0-9_\-\.\u4e00-\u9fa5])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,8})$/; w("pattern.test('cn42du@163.com') = "+pattern.test('cn42du@163.com')+";"); w("pattern.test('ifat3@sina.com.cn') = "+pattern.test('ifat3@sina.com.cn')+";"); w("pattern.test('ifat3.it@163.com') = "+pattern.test('ifat3.it@163.com')+";"); w("pattern.test('ifat3_-.@42du.cn') = "+pattern.test('ifat3_-.@42du.cn')+";"); w("pattern.test('ifat3@42du.online') = "+pattern.test('ifat3@42du.online')+";"); w("pattern.test('毛三胖@42du.cn') = "+pattern.test('毛三胖@42du.cn')+";"); function w(val) { document.getElementById("main").innerHTML += val +"<br />"; } </script> </body> </html>
테스트 결과:
pattern.test('cn42du@163.com') = true; pattern.test('ifat3@sina.com.cn') = true; pattern.test('ifat3.it@163.com') = true; pattern.test('ifat3_-.@42du.cn') = true; pattern.test('ifat3@42du.online') = true; pattern.test('毛三胖@42du.cn') = true;
옵션 3(안전)
휴대전화 인증코드가 나타나기 전, 거의 이메일 인증이 보장됩니다. 사용자 고유성에 대한 유일한 조건입니다. 임시 사서함(10분 사서함 또는 일회용 사서함이라고도 함)의 출현으로 인해 사서함 확인 및 계정 활성화 메커니즘이 의미가 없게 됩니다. 임시 이메일 주소의 주소는 열거할 수 없으므로 제한된 수의 이메일 도메인 이름만 확인을 통과하도록 허용하기 위해 화이트리스트만 사용할 수 있습니다.
플랜 1의 다음 추가 규칙에 따라:
이메일 도메인 이름은 163.com, qq.com 또는 42du.cn만 가능합니다.
정규식은 다음과 같습니다.
var pattern = /^([A-Za-z0-9_\-\.])+\@(163.com|qq.com|42du.cn)$/;
완전한 테스트 코드
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title>邮箱/邮件地址的正则表达式及分析(JavaScript,email,regex)</title> </head> <body> <p id="main"></p> <script> var pattern = /^([A-Za-z0-9_\-\.])+\@(163.com|qq.com|42du.cn)$/; w("pattern.test('cn42du@163.com') = "+pattern.test('cn42du@163.com')+";"); w("pattern.test('ifat3@sina.com.cn') = "+pattern.test('ifat3@sina.com.cn')+";"); w("pattern.test('ifat3.it@163.com') = "+pattern.test('ifat3.it@163.com')+";"); w("pattern.test('ifat3_-.@42du.cn') = "+pattern.test('ifat3_-.@42du.cn')+";"); w("pattern.test('ifat3@42du.online') = "+pattern.test('ifat3@42du.online')+";"); w("pattern.test('毛三胖dd@42du.cn') = "+pattern.test('毛三胖@42du.cn')+";"); function w(val) { document.getElementById("main").innerHTML += val +"<br />"; } </script> </body> </html>
테스트 결과:
pattern.test('cn42du@163.com') = true; pattern.test('ifat3@sina.com.cn') = false; pattern.test('ifat3.it@163.com') = true; pattern.test('ifat3_-.@42du.cn') = true; pattern.test('ifat3@42du.online') = false; pattern.test('毛三胖dd@42du.cn') = false;
스킴 3 검증은 보안을 보장할 수 있지만 화이트리스트가 너무 길면 패턴 string도 너무 길어집니다. 이때 이메일 도메인 이름 화이트리스트를 배열로 작성하고, 1차 검증에는 정규식을, 도메인 이름의 2차 검증에는 화이트리스트를 사용할 수 있습니다.
이제 이메일 확인 기능이 다음과 같이 제공됩니다.
var isEmail = function (val) { var pattern = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/; var domains= ["qq.com","163.com","vip.163.com","263.net","yeah.net","sohu.com","sina.cn","sina.com","eyou.com","gmail.com","hotmail.com","42du.cn"]; if(pattern.test(val)) { var domain = val.substring(val.indexOf("@")+1); for(var i = 0; i< domains.length; i++) { if(domain == domains[i]) { return true; } } } return false; } // 输出 true isEmail(cn42du@163.com);
이 기사의 사례를 읽으신 후 방법을 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 자료:
양식 입력 구성 요소에 Vue.js 사용자 정의 이벤트를 사용하는 방법
Vue가 다음 표를 사용하여 배열을 수정할 때 페이지가 렌더링되지 않는 문제를 처리하는 방법
위 내용은 정규 표현식을 사용하여 이메일 주소/이메일 주소 필터링의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사는 공식 웹 사이트에 액세스하는 것부터 등록 정보 작성, 등록 정보 작성, 확인, 사용자 계약 읽기 등의 모든 단계를 다루는 자세한 Gate.io 등록 자습서를 제공합니다.이 기사는 또한 2 차 검증을 설정하고 실제 인증을 설정하고 초보자의 디지털 자산 거래를 시작하는 등의 성공적인 등록을 성공적으로 등록한 후 보안 조치를 강조합니다.

이 기사는 초보자에게 자세한 GATE.IO 등록 자습서를 제공하여 공식 웹 사이트 액세스, 정보 작성, 신원 확인 등을 포함하여 등록 프로세스를 점차적으로 완료하도록 안내하고 등록 후 보안 설정을 강조합니다. 또한이 기사는 Binance, Ouyi 및 참깨 오픈 도어와 같은 다른 교환을 언급했습니다. 초보자는 자신의 요구에 따라 올바른 플랫폼을 선택하고 독자들에게 디지털 자산 투자가 위험하고 합리적으로 투자해야한다는 것을 상기시키는 것이 좋습니다.

로그인 단계 및 암호 복구 프로세스를 포함하여 참깨 오픈 exchange 웹 버전의 로그인 작업에 대한 자세한 소개는 로그인 실패, 페이지를 열 수 없으며 플랫폼에 부드럽게 로그인 할 수없는 일반적인 문제에 대한 솔루션을 제공합니다.

Laravel의 이메일을 처리하지 않는 방법은 LaRavel을 사용하는 것입니다.

Laravel 이메일 전송이 실패 할 때 반환 코드를 얻는 방법. Laravel을 사용하여 응용 프로그램을 개발할 때 종종 확인 코드를 보내야하는 상황이 발생합니다. 그리고 실제로 ...

이 기사는 사용자가 디지털 자산 거래를 쉽게 시작할 수 있도록 자세한 Gate.io 웹 버전 최신 등록 자습서를 제공합니다. 이 자습서는 공식 웹 사이트에 액세스하는 것부터 등록 완료에 이르기까지 모든 단계를 다루고 등록 후 보안 설정을 강조합니다. 이 기사는 또한 Binance, Ouyi 및 참깨 오픈 도어와 같은 다른 거래 플랫폼을 간략하게 소개합니다. 사용자는 자신의 요구에 따라 올바른 플랫폼을 선택하고 투자 위험에주의를 기울이는 것이 좋습니다.

OKX OUYI는 주요 암호 화폐 거래 플랫폼입니다. 이 기사는 OKX OUYI 공식 웹 사이트 계정을 등록하는 방법에 대한 자세한 단계를 제공합니다. 공식 웹 사이트에 액세스하는 방법을 배우고 등록 방법을 선택하고 필요한 정보를 작성하고 등록 절차를 완료합니다. 이 기사에는 실제 개인 정보를 사용하는 것의 중요성과 강력한 비밀번호를 설정하는 것과 같은 예방 조치에 대한 정보도 포함되어 있습니다.

Gateio Exchange 앱은 공식, 제 3 자 애플리케이션 시장, 포럼 커뮤니티 및 기타 채널을 다루는 기존 버전의 채널을 다운로드합니다. 또한 기존 버전을 쉽게 얻고 새로운 버전 또는 장치 호환성을 사용하여 불편 함 문제를 해결하는 데 도움이됩니다.
