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方法
Sep 29 Javascript
js点击事件链接的问题解决
Apr 25 Javascript
javascript 10进制和62进制的相互转换
Jul 31 Javascript
javascript浏览器窗口之间传递数据的方法
Jan 20 Javascript
js判断手机端(Android手机还是iPhone手机)
Jul 22 Javascript
JavaScript常用本地对象小结
Mar 28 Javascript
Node.js 日志处理模块log4js
Aug 28 Javascript
Vue.js实现简单ToDoList 前期准备(一)
Dec 01 Javascript
在vue项目中安装使用Mint-UI的方法
Dec 27 Javascript
jQuery实现的电子时钟效果完整示例
Apr 28 jQuery
vue 实现LED数字时钟效果(开箱即用)
Dec 08 Javascript
优化Vue中date format的性能详解
Jan 13 Javascript
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
在PHP3中实现SESSION的功能(一)
2006/10/09 PHP
PHP 加密/解密函数 dencrypt(动态密文,带压缩功能,支持中文)
2009/01/30 PHP
深入php socket的讲解与实例分析
2013/06/13 PHP
php读取纯真ip数据库使用示例
2014/01/26 PHP
推荐5款跨平台的PHP编辑器
2014/12/25 PHP
PHP实现支持SSL连接的SMTP邮件发送类
2015/03/05 PHP
JS增加行复制行删除行的实现代码
2013/11/09 Javascript
jQuery多项选项卡的实现思路附样式及代码
2014/06/03 Javascript
教你如何自定义百度分享插件以及bshare分享插件的分享按钮
2014/06/20 Javascript
Jquery响应回车键直接提交表单操作代码
2014/07/25 Javascript
深入理解javascript变量声明
2014/11/20 Javascript
Angular.js中ng-if、ng-show和ng-hide的区别介绍
2017/01/20 Javascript
jQuery实现单击按钮遮罩弹出对话框效果(2)
2017/02/20 Javascript
原生JS实现圆环拖拽效果
2017/04/07 Javascript
详谈js中标准for循环与foreach(for in)的区别
2017/11/02 Javascript
js 原生判断内容区域是否滚动到底部的实例代码
2017/11/15 Javascript
vue用递归组件写树形控件的实例代码
2018/07/19 Javascript
关于Python中空格字符串处理的技巧总结
2017/08/10 Python
python 动态生成变量名以及动态获取变量的变量名方法
2019/01/20 Python
TensorFlow中如何确定张量的形状实例
2020/06/23 Python
Python 利用flask搭建一个共享服务器的步骤
2020/12/05 Python
CSS3基础(RGBa、text-shadow、box-shadow、border-radius)
2012/11/13 HTML / CSS
CSS3 实现穿梭星空动画
2020/11/13 HTML / CSS
html5自动播放mov格式视频的实例代码
2020/01/14 HTML / CSS
阿拉伯世界最大的电子商务网站:Souq沙特阿拉伯
2016/10/28 全球购物
Rodd & Gunn澳大利亚官网:新西兰男装品牌
2018/09/25 全球购物
艺术家策划的室内设计:Curious Egg
2019/03/06 全球购物
德国自然时尚和有机产品购物网站:Waschbär
2019/05/29 全球购物
创伤外科专业推荐信范文
2013/11/19 职场文书
流动人口婚育证明范本
2014/09/26 职场文书
小兵张嘎观后感
2015/06/03 职场文书
民间借贷纠纷答辩状
2015/08/03 职场文书
来探秘“德国中小企业”的成功之道
2019/07/26 职场文书
研究生学习计划书应该怎么写?
2019/09/10 职场文书
go类型转换及与C的类型转换方式
2021/05/05 Golang
教你在 Java 中实现 Dijkstra 最短路算法的方法
2022/04/08 Java/Android