js校验身份证
1
<%@page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<%@taglib prefix="rdp" uri="http://www.szfesc.cn/rdp" %> <!DOCTYPE html>
<html lang="zh-cn">
<head>
<title>新增客户黑名单信息</title>
<script type="text/javascript">
//去掉无证件下拉选择项
$(document).ready(function() {
$('#certTypes option[value="00"]').remove();
}); //提交表单时校验
function checkSubForm(){
var obj = $('#myForm'),
certyType = $.trim($('#certTypes option:selected').val()),
chgflag = false;
console.log(certyType);
//验证身份证格式
if(certyType == '01'){
var idcard = $.trim($('#certno').val());
if(idcard.length !=0 ){
chgflag = isIdCardNo(idcard)
}
if(!chgflag){
$('#certno').focus();
return false;
}
}
obj.submit();
return true;
}
</script>
</head>
<body>
<div class="row">
<div class="panel panel-default">
<div class="panel-heading">
<span class="glyphicon glyphicon-plus"></span>
新增客户黑名单信息
</div> <div class="panel-body">
<form class="form-horizontal rdpForm" role="form" id="myForm"
action="${ctx }/riskmgr/custblacklist/create" method="post" enctype="multipart/form-data">
<div class="form-group">
<label for="certtype" class="col-sm-2 control-label"><span>*</span>
证件类型</label>
<div class="col-sm-3">
<rdp:dictForm class="form-control" sectionId="certType" required="true"
selectedValue="${cblParam.certtype }" name="certtype" id="certTypes"
emptyOptionLabel="----请选择----" showValue="false" emptyOption="false"/>
</div>
<rdp:token />
</div>
<div class="form-group">
<label for="certno" class="col-sm-2 control-label"><span>*</span>
证件号</label>
<div class="col-sm-3">
<input type="text" class="form-control" name="certno" id="certno"
placeholder="证件号" required numberLetter="true"
lengthlimit="32" value="${cblParam.certno }">
</div>
</div>
<div class="form-group">
<label for="clientname" class="col-sm-2 control-label"><span>*</span>
姓名</label>
<div class="col-sm-3">
<input type="text" class="form-control" name="clientname"
placeholder="姓名" required
lengthlimit="120" value="${cblParam.clientname }">
</div>
</div>
<div class="form-group">
<label for="reasoncode" class="col-sm-2 control-label"><span>*</span>
录入原因码</label>
<div class="col-sm-3">
<rdp:dictForm sectionId="custBlacklistReasonCode" required="true" class="form-control"
name="reasoncode" selectedValue="${cblParam.reasoncode}"
emptyOptionLabel="----请选择----" emptyOption="false"/>
</div>
</div>
<div class="form-group">
<label for="blackreason" class="col-sm-2 control-label"><span>*</span>
录入原因</label>
<div class="col-sm-8">
<textarea rows="3" class="form-control" name="blackreason" required="true" lengthlimit="512" placeholder="只允许输入不超过512个字符!">${cblParam.blackreason }</textarea>
</div>
</div>
<div class="form-group">
<label for="context" class="col-sm-2 control-label">附件<a href="#" onclick="addFileInput();" title="新增附件" ><span class="glyphicon glyphicon-plus"></span></a></label>
<div class="col-sm-8">
<input type="hidden" name="filetype" value="11"/>
<input type="file" multiple="multiple" class="form-control" filetype="*.pdf;*.txt;*.doc;*.docx;*.xls;*.xlsx;*.jpg;*.jpeg;*.gif;*.png;*.bmp" name="uploadfile" placeholder="附件" value="" />
<span id="fileLabelId" style="color:#7B7B7B;">支持格式:*.pdf;*.txt;*.doc;*.docx;*.xls;*.xlsx;*.jpg;*.jpeg;*.gif;*.png;*.bmp;限制100M以内。</span>
</div>
</div>
<div class="form-group">
<label for="memo" class="col-sm-2 control-label">备注</label>
<div class="col-sm-8">
<textarea rows="5" cols="10" class="form-control" name="memo" lengthlimit="254" placeholder="只允许输入不超过254个字符!">${sysParam.memo }</textarea>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-success" onclick="return checkSubForm();">保存</button>
<a href="${ctx }/riskmgr/custblacklist?${qryStr}" class="btn btn-default">取消</a>
</div>
</div>
</form>
</div>
</div>
</div>
</body>
</html>
1
/**
* 身份证认证
* @param {Object} num
* @return {TypeName}
*/
function isIdCardNo(num){
num = num.toUpperCase();
//身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。
if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(num))){
alert('输入的身份证号长度不对,或者号码不符合规定!\n15位号码应全为数字,18位号码末位可以为数字或X。');
return false;
}
//校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
//下面分别分析出生日期和校验位
var len, re;
len = num.length;
if (len == 15){
re = new RegExp(/^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/);
var arrSplit = num.match(re);
//检查生日日期是否正确
var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]);
var bGoodDay;
bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
if(!bGoodDay){
alert('身份证号码日期格式不正确!');
return false;
}else{
//将15位身份证转成18位
//校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
var nTemp = 0, i;
num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6);
for(i = 0; i < 17; i ++){
nTemp += num.substr(i, 1) * arrInt[i];
}
num += arrCh[nTemp % 11];
return num;
}
}
if (len == 18){
re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/);
var arrSplit = num.match(re);
//检查生日日期是否正确
var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
var bGoodDay;
bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
if (!bGoodDay){
alert('身份证号码日期格式不正确!');
return false;
}else{
//检验18位身份证的校验码是否正确。
//校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
var valnum;
var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
var nTemp = 0, i;
for(i = 0; i < 17; i ++){
nTemp += num.substr(i, 1) * arrInt[i];
}
valnum = arrCh[nTemp % 11];
if (valnum != num.substr(17, 1)) {
alert('18位身份证的校验码不正确!应该为:' + valnum);
return false;
}
return num;
}
}
return true;
}
1
js校验身份证的更多相关文章
- JS校验身份证号的合法性
前端表单中有身份证号的校验,下边是用JS来校验身份证号的合法性. 中国居民身份证号码编码规则 第一.二位表示省(自治区.直辖市.特别行政区). 第三.四位表示市(地级市.自治州.盟及国家直辖市所属市辖 ...
- js 校验身份证号
根据地区编码.身份证格式.18位身份证需要验证最后一位校验位 //校验身份证 function IdentityCodeValid(code) { var city = { 11: "北京& ...
- 身份证号正则校验(js校验+JAVA校验)
js校验身份证号[15位和18位] 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 3 ...
- 身份证校验,前台js校验,后台java校验
js校验: var vcity={ 11:"北京",12:"天津",13:"河北",14:"山西",15:"内 ...
- Js完美验证15/18身份证,Js验证身份证,支持15/18位
Js完美验证15/18身份证,Js验证身份证,支持15/18位 >>>>>>>>>>>>>>>>> ...
- JS验证身份证
话不多说,直接看代码 JS部分 /** * 身份证15位编码规则:dddddd yymmdd xx p * dddddd:地区码 * yymmdd: 出生年月日 * xx: 顺序类编码,无法确定 * ...
- js验证身份证号,超准确
js验证身份证号,超准确 看程序前先来了解下身份证号的构成:身份证号分为两种,旧的为15位,新的为18位.身份证15位编码规则:dddddd yymmdd xx p 其中 dddddd:地区码 ...
- js 根据身份证获取出生日期及性别
js根据身份证获取出生日期及性别 CreateTime--2017年6月2日11:45:16Author:Marydon 第一步:身份证号格式校验 /** * 身份证号格式校验 */ functi ...
- 一些常见的js校验
今天有时间来总结一下那些常用的js校验: vernull = function(value){//非空校验 if(value.trim(value).length == 0){ return fals ...
随机推荐
- javascript对象(1)
今天说面向对象,嗯,不是那个对象,是这个对象. 接下来就开始今天的内容: 什么是面向对象: 就是把数据及数据的操作方法放在一起,作为一个相互依存的整体----对象.对同类对象抽象出其共性,形成类. 类 ...
- 关于MATLAB处理大数据坐标文件2017624
经过一个下午找资料,已作出人工轨迹记录程序,这样就可以增加样本容量 接下来三个方向:特征.决策树.机械轨迹程序 虽然机械轨迹的程序相对好做,但是现有机械轨迹程序太过于死板,不能自行更改轨迹
- 持续集成篇 --Hudson持续集成服务器的安装配置与使用
样例项目参考视频教程:http://www.roncoo.com/course/view/85d6008fe77c4199b0cdd2885eaeee53 IP:192.168.4.221 8G内存 ...
- SQL手动注入解析
作者:震灵 注入环境:DVWA 探测步骤: 1.首先探测是否可以注入以及注入方式 原SQL语句为 SELECT * FROM xxx WHERE a=''; 注入后为 SELECT * FROM xx ...
- [leetcode-594-Longest Harmonious Subsequence]
We define a harmonious array is an array where the difference between its maximum value and its mini ...
- 【Android Developers Training】 44. 控制你应用的音量和播放
注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...
- Hadoop各种进程的配置文件及其位置说明
hdfs DameNode core-site.xml <!--设置主机的IP和端口--> <property> <name>fs.defaultFS</na ...
- View学习(三)- View的布局(layout)过程
前段开始学习View的工作原理,前两篇博客的草稿都已经写好了,本想一鼓作气写完所有的相关文章,然后经历了一段连续加班,结果今天准备继续写文章时,把之前写好的东西都忘记了,又重新梳理了一遍,所以说那怕就 ...
- Spring Security4实例(Java config 版) —— Remember-Me
本文源码请看这里 相关文章: Spring Security4实例(Java config版)--ajax登录,自定义验证 Spring Security提供了两种remember-me的实现,一种是 ...
- 基本的传染病模型:SI、SIS、SIR及其Python代码实现
本文主要参考博客:http://chengjunwang.com/en/2013/08/learn-basic-epidemic-models-with-python/.该博客有一些笔误,并且有些地方 ...