`
yzz9i
  • 浏览: 218066 次
  • 性别: Icon_minigender_1
  • 来自: 湖南
社区版块
存档分类
最新评论

用户注册验证采用正则表达式【用户名 和 密码 及邮箱验证 时间格式 等】

阅读更多

  

用正则表达式验证Email的合法性;

Email验证的正则表达式:
/^[A-Za-z_]+([\w-\.]+)([A-Za-z]+)@((\w[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})$/i

   
用正则表达式验证Visa卡的合法性;
VisaCard必须由16位数字组成,首位数字必须以4开头,每四位用-或者空格分隔,因此正则表达式为:
/^4\d{3}[\s\-]?\d{4}[\s\-]?\d{4}[\s\-]?\d{4}$/

   
用正则表达式验证身份证的合法性;
身份证是18位数字,根据GB11643-1999《公民身份证》定义制作;由17为本体码和一位校验码组成;
身份证号前6位是地址码,按(GB/T2260)规定执行;
接着是8位年月日;
后三位同年同月同日出生人的顺序号,奇数表示男,偶数表示女;
最后一位是校验码,详细见程序处理
因此正则表达式验证模式:/^d{17}(\d|X)$/

<script type="text/javascript" language="javascript">
<!--
    function checkEmail(){ 
   
      var re=/^[A-Za-z_]+([\w-\.]+)([A-Za-z]+)@((\w[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})$/i;
      var email=document.getElementById('emailid').value;
      if(email!=null && email.length>0){
            if(re.test(email))
            {
                alert("Thanks,你输入的Email合法!");
            }
            else
            {
                alert("Sorry,你输入的Email不合法!");
            }
        }
      else
      {
            alert("请输入Email!");
       }
    }
  


   //验证Visa卡号是否正确
   function checkVisa(){
        //VisaCard必须由16位数字组成,首位数字必须以4开头,每四位用-或者空格分隔,正则表达式可以为
        var re=/^4\d{3}[\s\-]?\d{4}[\s\-]?\d{4}[\s\-]?\d{4}$/;
        var VisaCard=document.getElementById('visaid').value;
        if (VisaCard.length>0 && VisaCard!=null)
        {
            if(re.test(VisaCard))
            {
                alert("Thanks,您的VisaCard合法!");
            }
            else
            {
                alert("Sorry,您的VisaCard有误!");
            }
        }
        else
        {
            alert("请输入VisaCard!");
        }
   }
  
   //验证身份证号
   var vcity={ 11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",
               21:"辽宁",22:"吉林",23:"黑龙江",31:"上海",32:"江苏",
               33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",
               42:"湖北",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",
               51:"四川",52:"贵州",53:"云南",54:"西藏",61:"陕西",62:"甘肃",
               63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外"}
  
   function checkCard()
   {
        var isum=0;
        var re=/^\d{17}(\d|X)$/i;
        var cardidstr=document.getElementById('cardid').value;

if (cardidstr.length>0 && cardidstr!=null)
        {
            if(!re.test(cardidstr))
            {
                alert("卡号不符合要求!");
                return false;
            }
           
            //检查地址是否符合要求
            if(vcity[parseInt(cardidstr.substr(0,2))]==null)
            {
                alert("身份地址不符合要求!");
                return false;
            }
           
            //检查出生日期是否合法
            sbirthday=cardidstr.substr(6,4)+"-"+Number(cardidstr.substr(10,2))+"-" + Number(cardidstr.substr(12,2));
            var date=new Date(sbirthday.replace(/-/g,"/"));
            //alert("出生日期:"+sbirthday);
            if(sbirthday!=(date.getFullYear()+"-"+date.getMonth()+"-"+date.getDate())){
                //alert("出生日期非法!"+date.getFullYear()+"-"+date.getMonth()+"-"+date.getDate() +cardidstr.substr(10,2));
                alert("出生日期非法!"+date.getFullYear()+"-"+date.getMonth()+"-"+date.getDate());
                return false;
            }
            //检查验证码是否合法
            for(var i=17;i>=0;i--){
           
                isum+=(Math.pow(2,i)%11)*parseInt(cardidstr.charAt(17-i),11);
            }
            if(isum%11!=1){
                alert("验证码非法!");
                return false;
            }
           
            alert('身份证地址:'+vcity[parseInt(cardidstr.substr(0,2))]+"\n"
                 +"出生日期:"+sbirthday+"\n"
                 +"性别:"+(cardidstr.substr(16,1)%2?"男":"女"));
        }
        else
        {
            alert("请输入身份证号!");
        }   
   }
  
   //清空Email
   function resetEmail()
   {
        document.getElementById('emailid').value="";
   }
   //清空Visa卡
   function resetVisa()
   {
        document.getElementById('visaid').value="";
   }
  
   //清空身份证
   function resetCardId()
   {
        document.getElementById('cardid').value="";
   }

</script>

//-->

 

 

使用正则表达式对象RegExp:

 


/** 
 
* 这里主要是用了正则表达式来实现。在js中使用  
* 正则需要先创建一个RegExp对象,它的创建有两 
* 种,一时显示的创建,二是隐形的创建。两种创 
* 建方式在以下例子中都有,而且在IE中测试通过。 
*/ 
 
/** 
  * isStcokName 判断输入的是否为网页链接 
  * @param {String} stockname 网页链接 
  */ 
function isStcokName(stockname) {  
    if(stockname===null||stockname.length===0){  
        return false;  
    }  
      
    stockname=trim(stockname);//删除股票名称的前后空格  
      
    //判断输入的推荐人名称是否为以http开头,任意字符结尾,长度任意的字符串  
    var regex=RegExp("^\\D{3,5}$");  
    if(!stockname.match(regex)){  
        return false;  
    }  
    else{  
        return true;   
    }  
}  
   
/** 
  * isStockCode 
  * 判断股票代码是否为6位数,是否为空 
  * @param {String} stockcode 股票代码 
  */ 
function isStockCode(stockcode) {  
    if(stockcode===null||stockcode.length===0){  
        return false;  
    }  
      
    stockcode=trim(stockcode);//删除股票代码的前后空格  
      
    //判断股票代码是否为一个数字头数字结尾的,总个数为6的字符串  
    var regex=RegExp("^\\d{6}$");  
    if(!stockcode.match(regex)){  
        return false;   
    }  
    else{  
        return true;   
    }  
}  
    
  /** 
   * isRecommender 判断是否为推荐者 
   * @param {String} recommender  
   */ 
function isRecommender(recommender) {  
    if(recommender===null||recommender.length===0){  
        return false;  
    }  
      
    recommender=trim(recommender);//删除推荐人的前后空格  
      
    //判断输入的推荐人名称是否为以非数字开头,非数字结尾,总个数为3至18个的字符串  
    var regex=RegExp("^\\D{2,18}$");  
    if(!recommender.match(regex)){  
        return false;  
    }  
    else{  
        return true;   
    }  
}  
   
/** 
* vldtTimeFormat 
* 验证输入的时间格式是否正确 
* @param {String} datetime 日期时间 
*/ 
function isDateTime(datetime) {  
    if(datetime===null||datetime.length===0){  
        return false;  
    }  
      
    datetime=trim(datetime);//删除日期的前后空格  
      
    //创建正则表达式对象,隐形的创建方式  
    var regex=/^(20[0-9][0-9][-年])?[0-1]?[0-9][-月][0-3]?[0-9]日? ?[0-2]?[0-9][:点时][0-5]?[0-9][:分]?([0-5]?[0-9])?$/;  
    //测试正则表达式是否匹配  
    if (!regex.test(datetime)){  
        return false;  
    }  
    else{  
        return true;   
    }  
       
}  
   
/** 
  * isUrl 判断输入的是否为网页链接 
  * @param {String} url 网页链接 
  */ 
function isUrl(url) {  
    if(url===null||url.length===0){  
        return false;  
    }  
      
    url=trim(url);//删除url的前后空格  
      
    //判断输入的推荐人名称是否为以http开头,任意字符结尾,长度任意的字符串  
    var regex=RegExp("^http://.*$");  
    if(!url.match(regex)){  
        return false;  
    }  
    else{  
        return true;   
    }  
}  
 
/** 
  * 删除指定字符串的前后空格 
  */ 
function trim(string){  
      
     //使用这则表达式来替换字符串的前后空格  
    string=string.replace(/(^\s*)|(\s*$)/g, "");  
      
    return string;  
}  

 

 

3
4
分享到:
评论

相关推荐

    js正则练习-账号密码邮箱匹配

    利用正则表达式,匹配账号密码邮箱,如有误则提示错误

    正则表达式判断用户信息

    通过正则表达式的使用,判断用户注册信息中的邮箱、电话、密码信息是否符合要求。

    php用户注册信息验证正则表达式

    各种网页脚本也都常用“正则表达式”(regular expression)对我们信息进行验证,判断是否合法,本文为大家介绍了php用户注册验证正则表达式,需要的朋友可以参考下

    js注册检测 用户名、密码、手机号、邮箱

    JS注册检测是指在用户注册时对用户名、密码、手机号、邮箱等信息进行检测,以确保用户输入的信息合法有效。本文将详细介绍JS注册检测的实现过程和检测原理。 一、用户名检测 用户名检测是指检测用户输入的用户名...

    正则表达式–QQ微信、优酷前端 邮箱正则表达式验证 Bug

    拿邮箱验证来说,网上绝大部分人写的邮箱验证正则表达式代码都不能验证这邮箱: i@julying.com,也不能验证 xxxxxx@i.com 。 上次我发现youku.com(优酷网)用户注册就有这个问题,见图:   ...

    Python程序设计:邮箱验证(案例).pptx

    邮箱具有一定的规则,在用户注册邮箱时,必须遵守这些规则。正则表达式是一个特殊的字符序列,它能方便的检查一个字符串是否与某种模式匹配,利用正则可以快速准确的对邮箱进行校验。 任务 邮箱验证 任务目标 理解...

    javascript使用正则表达式实现注册登入校验

    本文实例为大家分享了用正则表达式的方式实现注册登入的校验,供大家参考,具体内容如下 表单验证: 1、用户名:6–18位数字,字母,下划线_,文本域获取焦点和失去焦点出现提示文字。 2、登入密码:请输入6–20位数字...

    jQuery正则验证注册页面经典实例

    主要介绍了jQuery正则验证注册页面功能,涉及针对用户名、密码、邮箱、手机号等的正则验证操作技巧,需要的朋友可以参考下

    日常收集JS邮箱验证正则表达式

    背景:正则是一门厚书啊,想写好也不容易,但日常中也就那些像电话、邮箱、手机,网上一堆,但真好验证好了,还得了解一点正则知识,再就是多测试了:-) 下面邮箱正则: 中划线:中划线域名就是米农口中说的扁担...

    正则表达式验证身份证号码和邮箱、判断checked选中状态

    项目中正好写到登录注册,在用blur事件验证用户输入内容的时候,出现了点bug,最后是在注册按钮onclick的事件里获取用户输入值来验证的。 判断checked选中状态: if(!$('#checkedAgree').prop("checked"){ console...

    html网页用户注册表单验证校验JavaScript源码代码

    html网页用户注册表单验证校验JavaScript源码代码,完整代码已经打包,还迎下载,代码仅供学习参考。 function checkuser(){//检查用户名的方法 var usernameNode=document.getElementById("username");//通过id...

    图书管理系统 大二上学期的期末大作业。感觉是一个不错的Javaweb的练手项目hh。

    输入用户的信息进行注册(这些内容都可使用正则表达式进行验证) 学号:必填、不可更改、不可重复(使用Ajax异步进行数据库的连接验证学号是否重复) 密码:长度限制 手机号:格式限制(可能需要发送验证码?) 邮箱...

    捐助网站评价

    应实现的效果 :焦点离开编辑框就做验证 a、是否满足输入的格式(用正则表达式)b、注册的用户和邮箱是否已注册 c、在我要注册中同时也要做以上验证 d、两次输入的密码要一致 注册完了注意页面的切换 (2) 登陆 ...

    php用户注册时常用的检验函数实例总结

    php用户注册时常用的一些常用检验函数总结,包括有检测提交的数据是否符合用户名格式,检测参数的值是否相同,检测参数是否为中文,检验邮箱的地址是否正确,检验参数是否为数字等等,这些提交到数据库之前的验证,在正则...

Global site tag (gtag.js) - Google Analytics