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 相关文章推荐
谷歌浏览器 insertCell与appendChild的区别
Feb 12 Javascript
js 禁用只读文本框获得焦点时的退格键
Apr 25 Javascript
JavaScript获取onclick、onchange等事件值的代码
Jul 22 Javascript
Jquery的hide及toggle方法让超链接慢慢消失
Sep 06 Javascript
深入分析js的冒泡事件
Dec 05 Javascript
JavaScript原生对象之Date对象的属性和方法详解
Mar 13 Javascript
kindeditor修复会替换script内容的问题
Apr 03 Javascript
js实现点击切换TAB标签实例
Aug 21 Javascript
jquery事件的ready()方法使用详解
Nov 11 Javascript
jQuery unbind()方法实例详解
Jan 19 Javascript
js实现返回顶部效果
Mar 10 Javascript
web页面和微信小程序页面实现瀑布流效果
Sep 26 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
解决PHP mysql_query执行超时(Fatal error: Maximum execution time …)
2013/07/03 PHP
PHP实现的连贯操作、链式操作实例
2014/07/08 PHP
PHP采用curl模仿用户登陆新浪微博发微博的方法
2014/11/07 PHP
使用XHGui来测试PHP性能的教程
2015/07/03 PHP
php快速排序原理与实现方法分析
2016/05/26 PHP
php中10个不同等级压缩优化图片操作示例
2016/11/14 PHP
PHP实现生成模糊图片的方法示例
2017/12/21 PHP
个人总结的一些关于String、Function、Array的属性和用法
2007/01/10 Javascript
JS获取dom 对象 ajax操作 读写cookie函数
2009/11/18 Javascript
script标签的 charset 属性使用说明
2010/12/04 Javascript
基于jquery的15款幻灯片插件
2011/04/10 Javascript
超轻量级的基于jquery的三级展开列表
2011/04/26 Javascript
如何使用jquery动态加载js,css文件实现代码
2013/04/03 Javascript
网页前端优化之滚动延时加载图片示例
2013/07/13 Javascript
Mac地址验证的javascript代码
2013/11/09 Javascript
.NET微信公众号开发之创建自定义菜单
2015/07/16 Javascript
jquery仅用6行代码实现滑动门效果
2015/09/07 Javascript
jQury Ajax使用Token验证身份实例代码
2017/09/22 Javascript
VueJS事件处理器v-on的使用方法
2017/09/27 Javascript
javascript中的隐式调用
2018/02/10 Javascript
python操作mysql代码总结
2018/06/01 Python
Django安装配置mysql的方法步骤
2018/10/15 Python
解决Python一行输出不显示的问题
2018/12/03 Python
Python爬虫:url中带字典列表参数的编码转换方法
2019/08/21 Python
python模块导入的方法
2019/10/24 Python
python装饰器的特性原理详解
2019/12/25 Python
浅谈pytorch 模型 .pt, .pth, .pkl的区别及模型保存方式
2020/05/25 Python
python如何处理程序无法打开
2020/06/16 Python
简约控的天堂:The Undone
2016/12/21 全球购物
应届毕业生就业自荐信
2013/10/26 职场文书
球队口号
2014/06/18 职场文书
元旦趣味活动方案
2014/08/22 职场文书
2014年后备干部工作总结
2014/12/08 职场文书
课程设计感想范文
2015/08/11 职场文书
《堡垒之夜》联动《刺客信条》 4月7日正式上线
2022/04/06 其他游戏
MySQL 原理优化之Group By的优化技巧
2022/08/14 MySQL