>  기사  >  웹 프론트엔드  >  JS 이메일 편지함/이메일 주소 정기 필터링 구현

JS 이메일 편지함/이메일 주소 정기 필터링 구현

php中世界最好的语言
php中世界最好的语言원래의
2018-05-25 09:58:412186검색

이번에는 JS 이메일/이메일 주소 정기 필터링 구현에 대해 알려드리겠습니다. 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(&#39;cn42du@163.com&#39;) = "+pattern.test(&#39;cn42du@163.com&#39;)+";");
  w("pattern.test(&#39;ifat3@sina.com.cn&#39;) = "+pattern.test(&#39;ifat3@sina.com.cn&#39;)+";");
  w("pattern.test(&#39;ifat3.it@163.com&#39;) = "+pattern.test(&#39;ifat3.it@163.com&#39;)+";");
  w("pattern.test(&#39;ifat3_-.@42du.cn&#39;) = "+pattern.test(&#39;ifat3_-.@42du.cn&#39;)+";");
  w("pattern.test(&#39;ifat3@42du.online&#39;) = "+pattern.test(&#39;ifat3@42du.online&#39;)+";");
  w("pattern.test(&#39;毛三胖@42du.cn&#39;) = "+pattern.test(&#39;毛三胖@42du.cn&#39;)+";");
  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(&#39;cn42du@163.com&#39;) = "+pattern.test(&#39;cn42du@163.com&#39;)+";");
  w("pattern.test(&#39;ifat3@sina.com.cn&#39;) = "+pattern.test(&#39;ifat3@sina.com.cn&#39;)+";");
  w("pattern.test(&#39;ifat3.it@163.com&#39;) = "+pattern.test(&#39;ifat3.it@163.com&#39;)+";");
  w("pattern.test(&#39;ifat3_-.@42du.cn&#39;) = "+pattern.test(&#39;ifat3_-.@42du.cn&#39;)+";");
  w("pattern.test(&#39;ifat3@42du.online&#39;) = "+pattern.test(&#39;ifat3@42du.online&#39;)+";");
  w("pattern.test(&#39;毛三胖@42du.cn&#39;) = "+pattern.test(&#39;毛三胖@42du.cn&#39;)+";");
  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(&#39;cn42du@163.com&#39;) = "+pattern.test(&#39;cn42du@163.com&#39;)+";");
  w("pattern.test(&#39;ifat3@sina.com.cn&#39;) = "+pattern.test(&#39;ifat3@sina.com.cn&#39;)+";");
  w("pattern.test(&#39;ifat3.it@163.com&#39;) = "+pattern.test(&#39;ifat3.it@163.com&#39;)+";");
  w("pattern.test(&#39;ifat3_-.@42du.cn&#39;) = "+pattern.test(&#39;ifat3_-.@42du.cn&#39;)+";");
  w("pattern.test(&#39;ifat3@42du.online&#39;) = "+pattern.test(&#39;ifat3@42du.online&#39;)+";");
  w("pattern.test(&#39;毛三胖dd@42du.cn&#39;) = "+pattern.test(&#39;毛三胖@42du.cn&#39;)+";");
  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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.