이번에는 JS 이메일/이메일 주소 정기 필터링 구현에 대해 알려드리겠습니다. JS 이메일/이메일 주소 정기 필터링의 주의 사항은 무엇인가요? 아래에서 실제 사례를 살펴보겠습니다.
간단히
사용자 등록을 할 때 이메일/이메일 주소라는 정규 표현을 자주 사용합니다. 이 문서에서는 프로젝트 상황에 따라 가장 적합한 옵션을 선택할 수 있습니다.
옵션 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})$/;
완전한 테스트 코드
nbsp;HTML> <meta> <title>邮箱/邮件地址的正则表达式及分析(JavaScript,email,regex)</title> <p></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>
테스트 결과:
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;
패턴 .test('ifat3@42du.online') = false;
pattern.test('Mao Sanpang@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('Mao Sanpang@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})$/;
전체 테스트 코드
nbsp;HTML> <meta> <title>邮箱/邮件地址的正则表达式及分析(JavaScript,email,regex)</title> <p></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>
테스트 결과:
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('Mao Sanpang@42du.cn') = true;
옵션 3(안전)
모바일에 앞서 전화 인증 코드가 나타나는데, 거의 이메일 인증이 사용자 고유성을 보장하는 유일한 조건입니다. 임시 사서함(10분 사서함 또는 일회용 사서함이라고도 함)의 출현으로 인해 사서함 확인 및 계정 활성화 메커니즘이 의미가 없게 됩니다. 임시 이메일 주소는 열거할 수 없습니다. 제한된 수의 이메일 도메인 이름만 확인을 통과하도록 허용하는 화이트리스트만 사용할 수 있습니다.
플랜 1의 다음 추가 규칙에 따라:
이메일 도메인 이름은 163.com, qq.com 또는 42du.cn만 가능합니다.
정규식은 다음과 같습니다.
var pattern = /^([A-Za-z0-9_\-\.])+\@(163.com|qq.com|42du.cn)$/;
완전한 테스트 코드
nbsp;HTML> <meta> <title>邮箱/邮件地址的正则表达式及分析(JavaScript,email,regex)</title> <p></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>
테스트 결과:
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<p style="text-align: left;">上述isEmail()函数列举了常用的11种邮箱域名,大家可以根据需要适当补充或删减。</p><p>相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!</p><p>推荐阅读:</p><p><a href="http://www.php.cn/js-tutorial-398128.html" target="_blank">JS数组方法使用步骤详解</a><br></p><p><a href="http://www.php.cn/js-tutorial-398124.html" target="_blank">行内元素padding和margin在什么情况下无效</a><br></p>
위 내용은 JS 이메일 편지함/이메일 주소 정기 필터링 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!