javascript 常用验证函数总结


Posted in Javascript onJune 28, 2016
/**
 * 2010-7-13
 * 贺 臣
 * 情 缘
 * js各种表单数据验证
 */
/**************************************************************************************/
/*************************************数字的验证*****************************************/
/**************************************************************************************/

/**
 * 检查输入的一串字符是否全部是数字
 * 输入:str 字符串
 * 返回:true 或 flase; true表示为数字
 */
function checkNum(str){
  return str.match(/\D/) == null;
}


/**
 * 检查输入的一串字符是否为小数
 * 输入:str 字符串
 * 返回:true 或 flase; true表示为小数
 */
function checkDecimal(str){
  if (str.match(/^-?\d+(\.\d+)?$/g) == null) {
    return false;
  }
  else {
    return true;
  }
}

/**
 * 检查输入的一串字符是否为整型数据
 * 输入:str 字符串
 * 返回:true 或 flase; true表示为小数
 */
function checkInteger(str){
  if (str.match(/^[-+]?\d*$/) == null) {
    return false;
  }
  else {
    return true;
  }
}

/**************************************************************************************/
/*************************************字符的验证*****************************************/
/**************************************************************************************/


/**
 * 检查输入的一串字符是否是字符
 * 输入:str 字符串
 * 返回:true 或 flase; true表示为全部为字符 不包含汉字
 */
function checkStr(str){
  if (/[^\x00-\xff]/g.test(str)) {
    return false;
  }
  else {
    return true;
  }
}


/**
 * 检查输入的一串字符是否包含汉字
 * 输入:str 字符串
 * 返回:true 或 flase; true表示包含汉字
 */
function checkChinese(str){
  if (escape(str).indexOf("%u") != -1) {
    return true;
  }
  else {
    return false;
  }
}


/**
 * 检查输入的邮箱格式是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 */
function checkEmail(str){
  if (str.match(/[A-Za-z0-9_-]+[@](\S*)(net|com|cn|org|cc|tv|[0-9]{1,3})(\S*)/g) == null) {
    return false;
  }
  else {
    return true;
  }
}


/**
 * 检查输入的手机号码格式是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 */
function checkMobilePhone(str){
  if (str.match(/^(?:13\d|15[89])-?\d{5}(\d{3}|\*{3})$/) == null) {
    return false;
  }
  else {
    return true;
  }
}


/**
 * 检查输入的固定电话号码是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 */
function checkTelephone(str){
  if (str.match(/^(([0\+]\d{2,3}-)?(0\d{2,3})-)(\d{7,8})(-(\d{3,}))?$/) == null) {
    return false;
  }
  else {
    return true;
  }
}

/**
 * 检查QQ的格式是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 */
function checkQQ(str){
  if (str.match(/^\d{5,10}$/) == null) {
    return false;
  }
  else {
    return true;
  }
}

/**
 * 检查输入的身份证号是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 */
function checkCard(str){
  //15位数身份证正则表达式
  var arg1 = /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;
  //18位数身份证正则表达式
  var arg2 = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[A-Z])$/;
  if (str.match(arg1) == null && str.match(arg2) == null) {
    return false;
  }
  else {
    return true;
  }
}

/**
 * 检查输入的IP地址是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 */
function checkIP(str){
  var arg = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/;
  if (str.match(arg) == null) {
    return false;
  }
  else {
    return true;
  }
}

/**
 * 检查输入的URL地址是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 */
function checkURL(str){
  if (str.match(/(http[s]?|ftp):\/\/[^\/\.]+?\..+\w$/i) == null) {
    return false
  }
  else {
    return true;
  }
}

/**
 * 检查输入的字符是否具有特殊字符
 * 输入:str 字符串
 * 返回:true 或 flase; true表示包含特殊字符
 * 主要用于注册信息的时候验证
 */
function checkQuote(str){
  var items = new Array("~", "`", "!", "@", "#", "$", "%", "^", "&", "*", "{", "}", "[", "]", "(", ")");
  items.push(":", ";", "'", "|", "\\", "<", ">", "?", "/", "<<", ">>", "||", "//");
  items.push("admin", "administrators", "administrator", "管理员", "系统管理员");
  items.push("select", "delete", "update", "insert", "create", "drop", "alter", "trancate");
  str = str.toLowerCase();
  for (var i = 0; i < items.length; i++) {
    if (str.indexOf(items[i]) >= 0) {
      return true;
    }
  }
  return false;
}


/**************************************************************************************/
/*************************************时间的验证*****************************************/
/**************************************************************************************/

/**
 * 检查日期格式是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 * 注意:此处不能验证中文日期格式
 * 验证短日期(2007-06-05)
 */
function checkDate(str){
  //var value=str.match(/((^((1[8-9]\d{2})|([2-9]\d{3}))(-)(10|12|0?[13578])(-)(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(11|0?[469])(-)(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(0?2)(-)(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)(-)(0?2)(-)(29)$)|(^([3579][26]00)(-)(0?2)(-)(29)$)|(^([1][89][0][48])(-)(0?2)(-)(29)$)|(^([2-9][0-9][0][48])(-)(0?2)(-)(29)$)|(^([1][89][2468][048])(-)(0?2)(-)(29)$)|(^([2-9][0-9][2468][048])(-)(0?2)(-)(29)$)|(^([1][89][13579][26])(-)(0?2)(-)(29)$)|(^([2-9][0-9][13579][26])(-)(0?2)(-)(29)$))/);
  var value = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
  if (value == null) {
    return false;
  }
  else {
    var date = new Date(value[1], value[3] - 1, value[4]);
    return (date.getFullYear() == value[1] && (date.getMonth() + 1) == value[3] && date.getDate() == value[4]);
  }
}

/**
 * 检查时间格式是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 * 验证时间(10:57:10)
 */
function checkTime(str){
  var value = str.match(/^(\d{1,2})(:)?(\d{1,2})\2(\d{1,2})$/)
  if (value == null) {
    return false;
  }
  else {
    if (value[1] > 24 || value[3] > 60 || value[4] > 60) {
      return false
    }
    else {
      return true;
    }
  }
}

/**
 * 检查全日期时间格式是否正确
 * 输入:str 字符串
 * 返回:true 或 flase; true表示格式正确
 * (2007-06-05 10:57:10)
 */
function checkFullTime(str){
  //var value = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/);
  var value = str.match(/^(?:19|20)[0-9][0-9]-(?:(?:0[1-9])|(?:1[0-2]))-(?:(?:[0-2][1-9])|(?:[1-3][0-1])) (?:(?:[0-2][0-3])|(?:[0-1][0-9])):[0-5][0-9]:[0-5][0-9]$/);
  if (value == null) {
    return false;
  }
  else {
    //var date = new Date(checkFullTime[1], checkFullTime[3] - 1, checkFullTime[4], checkFullTime[5], checkFullTime[6], checkFullTime[7]);
    //return (date.getFullYear() == value[1] && (date.getMonth() + 1) == value[3] && date.getDate() == value[4] && date.getHours() == value[5] && date.getMinutes() == value[6] && date.getSeconds() == value[7]);
    return true;
  }
  
}




/**************************************************************************************/
/************************************身份证号码的验证*************************************/
/**************************************************************************************/

/** 
 * 身份证15位编码规则:dddddd yymmdd xx p
 * dddddd:地区码
 * yymmdd: 出生年月日
 * xx: 顺序类编码,无法确定
 * p: 性别,奇数为男,偶数为女
 * <p />
 * 身份证18位编码规则:dddddd yyyymmdd xxx y
 * dddddd:地区码
 * yyyymmdd: 出生年月日
 * xxx:顺序类编码,无法确定,奇数为男,偶数为女
 * y: 校验码,该位数值可通过前17位计算获得
 * <p />
 * 18位号码加权因子为(从右到左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ]
 * 验证位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]
 * 校验位计算公式:Y_P = mod( ∑(Ai×Wi),11 )
 * i为身份证号码从右往左数的 2...18 位; Y_P为脚丫校验码所在校验码数组位置
 *
 */
var Wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1];// 加权因子  
var ValideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2];// 身份证验证位值.10代表X  
function IdCardValidate(idCard){
  idCard = trim(idCard.replace(/ /g, ""));
  if (idCard.length == 15) {
    return isValidityBrithBy15IdCard(idCard);
  }
  else 
    if (idCard.length == 18) {
      var a_idCard = idCard.split("");// 得到身份证数组  
      if (isValidityBrithBy18IdCard(idCard) && isTrueValidateCodeBy18IdCard(a_idCard)) {
        return true;
      }
      else {
        return false;
      }
    }
    else {
      return false;
    }
}

/** 
 * 判断身份证号码为18位时最后的验证位是否正确
 * @param a_idCard 身份证号码数组
 * @return
 */
function isTrueValidateCodeBy18IdCard(a_idCard){
  var sum = 0; // 声明加权求和变量  
  if (a_idCard[17].toLowerCase() == 'x') {
    a_idCard[17] = 10;// 将最后位为x的验证码替换为10方便后续操作  
  }
  for (var i = 0; i < 17; i++) {
    sum += Wi[i] * a_idCard[i];// 加权求和  
  }
  valCodePosition = sum % 11;// 得到验证码所位置  
  if (a_idCard[17] == ValideCode[valCodePosition]) {
    return true;
  }
  else {
    return false;
  }
}

/** 
 * 通过身份证判断是男是女
 * @param idCard 15/18位身份证号码
 * @return 'female'-女、'male'-男
 */
function maleOrFemalByIdCard(idCard){
  idCard = trim(idCard.replace(/ /g, ""));// 对身份证号码做处理。包括字符间有空格。  
  if (idCard.length == 15) {
    if (idCard.substring(14, 15) % 2 == 0) {
      return 'female';
    }
    else {
      return 'male';
    }
  }
  else 
    if (idCard.length == 18) {
      if (idCard.substring(14, 17) % 2 == 0) {
        return 'female';
      }
      else {
        return 'male';
      }
    }
    else {
      return null;
    }
}

/** 
 * 验证18位数身份证号码中的生日是否是有效生日
 * @param idCard 18位书身份证字符串
 * @return
 */
function isValidityBrithBy18IdCard(idCard18){
  var year = idCard18.substring(6, 10);
  var month = idCard18.substring(10, 12);
  var day = idCard18.substring(12, 14);
  var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
  // 这里用getFullYear()获取年份,避免千年虫问题  
  if (temp_date.getFullYear() != parseFloat(year) ||
  temp_date.getMonth() != parseFloat(month) - 1 ||
  temp_date.getDate() != parseFloat(day)) {
    return false;
  }
  else {
    return true;
  }
}

/** 
 * 验证15位数身份证号码中的生日是否是有效生日
 * @param idCard15 15位书身份证字符串
 * @return
 */
function isValidityBrithBy15IdCard(idCard15){
  var year = idCard15.substring(6, 8);
  var month = idCard15.substring(8, 10);
  var day = idCard15.substring(10, 12);
  var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
  // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法  
  if (temp_date.getYear() != parseFloat(year) ||
  temp_date.getMonth() != parseFloat(month) - 1 ||
  temp_date.getDate() != parseFloat(day)) {
    return false;
  }
  else {
    return true;
  }
}

//去掉字符串头尾空格  
function trim(str){
  return str.replace(/(^\s*)|(\s*$)/g, "");
}

以上就是本文的全部内容,了解更多JavaScript的语法,大家可以查看:《JavaScript 参考教程》、《JavaScript代码风格指南》,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js猜数字小游戏的简单实现代码
Jul 02 Javascript
简体中文转换繁体中文(实现代码)
Dec 25 Javascript
jQuery对指定元素中指定字符串进行替换的方法
Mar 17 Javascript
jQuery+css实现的tab切换标签(兼容各浏览器)
Jan 28 Javascript
JS实现重新加载当前页面
Nov 29 Javascript
js实现可以点击收缩或张开的悬浮窗
Sep 18 Javascript
浅谈JS 数字和字符串之间相互转化的纠纷
Oct 20 Javascript
JavaScript生成指定范围随机数和随机序列的方法
May 05 Javascript
vue :src 文件路径错误问题的解决方法
May 15 Javascript
浅谈webpack 构建性能优化策略小结
Jun 13 Javascript
JavaScript模板引擎原理与用法详解
Dec 24 Javascript
基于jquery实现的tab选项卡功能示例【附源码下载】
Jun 10 jQuery
JS传递对象数组为参数给后端,后端获取的实例代码
Jun 28 #Javascript
JavaScript ES5标准中新增的Array方法
Jun 28 #Javascript
jQuery 中ajax异步调用的四种方式
Jun 28 #Javascript
jQuery 调用WebService 实例讲解
Jun 28 #Javascript
关于在Servelet中如何获取当前时间的操作方法
Jun 28 #Javascript
关于JS 预解释的相关理解
Jun 28 #Javascript
checkbox批量选中,获取选中项的值的简单实例
Jun 28 #Javascript
You might like
整理的一些实用WordPress后台MySQL操作命令
2013/01/07 PHP
Mac系统下使用brew搭建PHP(LNMP/LAMP)开发环境
2015/03/03 PHP
php获得网站访问统计信息类Compete API用法实例
2015/04/02 PHP
简单PHP会话(session)说明介绍
2016/08/21 PHP
Django中的cookie与session操作实例代码
2017/08/17 PHP
jquery photoFrame 图片边框美化显示插件
2010/06/28 Javascript
jquery Moblie入门—hello world的示例代码学习
2013/01/08 Javascript
javaScript中的this示例学习详解及工作原理
2014/01/13 Javascript
jQuery事件绑定与解除绑定实现方法
2015/04/15 Javascript
JavaScript中Number.NEGATIVE_INFINITY值的使用详解
2015/06/05 Javascript
深入解读JavaScript中的Hoisting机制
2015/08/12 Javascript
angular2使用简单介绍
2016/03/01 Javascript
判断输入的字符串是否是日期格式的简单方法
2016/07/11 Javascript
解决node修改后需频繁手动重启的问题
2018/05/13 Javascript
vue项目打包部署到服务器的方法示例
2018/08/27 Javascript
jQuery使用$.extend(true,object1, object2);实现深拷贝对象的方法分析
2019/03/06 jQuery
js实现随机数小游戏
2019/06/28 Javascript
jQuery实现动态向上滚动
2020/12/21 jQuery
Python实现在线程里运行scrapy的方法
2015/04/07 Python
为Python的Tornado框架配置使用Jinja2模板引擎的方法
2016/06/30 Python
Python 字符串大小写转换的简单实例
2017/01/21 Python
Python爬虫实例扒取2345天气预报
2018/03/04 Python
Python tkinter label 更新方法
2018/10/11 Python
Python实现的读取文件内容并写入其他文件操作示例
2019/04/09 Python
Pandas数据离散化原理及实例解析
2019/11/16 Python
css sprite简单实例
2016/05/23 HTML / CSS
CSS3 二级导航菜单的制作的示例
2018/04/02 HTML / CSS
JAVA中的关键字有什么特点
2014/03/07 面试题
食品安全检查制度
2014/02/03 职场文书
总经理助理工作职责
2014/02/06 职场文书
中秋节活动总结
2014/08/29 职场文书
九华山导游词
2015/02/03 职场文书
合同审查法律意见书
2015/06/04 职场文书
python实战之一步一步教你绘制小猪佩奇
2021/04/22 Python
详解Django的MVT设计模式
2021/04/29 Python
golang 定时任务方面time.Sleep和time.Tick的优劣对比分析
2021/05/05 Golang