身份证上传示例

本文介绍了一个证券账户开通过程中的资料上传步骤,包括身份证或护照的正反面拍摄要求及住址证明的上传指引。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<%@page import="com.coactsoft.cfp.entity.CustomerStatus"%>
<%@page import="com.coactsoft.cfp.Constant"%>
<%@page import="com.coactsoft.cfp.utils.UserUtils"%>
<%@page import="com.coactsoft.cfp.entity.Customer"%>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%
String customerId = UserUtils.getUserId(request);
Customer customer = UserUtils.getUserStatus(request);
if ((customer.getStatus() > CustomerStatus.WYY || customer.getStatusMG() > CustomerStatus.WYY)
|| (customer.getStatus() != CustomerStatus.SCZL && customer.getStatusMG() != CustomerStatus.SCZL)) {
response.sendRedirect(request.getContextPath() + "/my/account/open.jsp");
return;
}
customer = UserUtils.getUserProofInfo(request);
pageContext.setAttribute("customer", customer);
//是否代交开户
Boolean substitute = request.getSession().getAttribute(Constant.SUBSTITUTE_APPOINTMENT) == null ? false : true;
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<jsp:include page="/WEB-INF/common/meta.jsp" />
<jsp:include page="/WEB-INF/common/taglib.jsp" />
<title>长复证券--开户--上传资料</title>
<link rel="stylesheet" href="${ctxResource}/css/style.css" />
<link rel="stylesheet" href="${ctxResource}/css/login.css" />
<link rel="stylesheet" href="${ctxResource}/validator/jquery.validator.css" />
<style type="text/css">
.cf-uploader-img a.cf-sfz {
padding-top: 0px;
background: none;
}
.cf-uploader-img a.cf-zhuzhi{
padding-top: 0px;
background: none;
}
.cf-uploader-img img{
margin: 0px auto;
text-align: center;
width: 264px;
height: 168px;
}
#infoForm .n-msg{font-size: 16px;line-height: 28px;margin-left: -65px;}
#infoForm .n-icon{display: none;}
</style>
<jsp:include page="/WEB-INF/common/js.jsp" />
<script type="text/javascript" src="${ctxResource}/plupload/plupload.full.min.js" ></script>
<script type="text/javascript" src="${ctxResource}/validator/jquery.validator.js"></script>
<script type="text/javascript" src="${ctxResource}/validator/local/zh-CN.js"></script>
<script type="text/javascript">
$(function() {
function createUpload(container, browseBtn) {
new plupload.Uploader({
runtimes : 'html5,flash,silverlight,html4',
browse_button : browseBtn,
container: document.getElementById(container),
url : ctxResource + "/plupload/Upload.jsp",
flash_swf_url : ctxResource + '/plupload/Moxie.swf',
silverlight_xap_url : ctxResource + '/plupload/Moxie.xap',
multipart_params:{'customer':'<%=customerId%>'},
filters : {max_file_num:3, max_file_size:'10mb',mime_types:[{title:"Image files", extensions:"jpg,jpeg,png,gif"}]},


init: {
BeforeUpload: function(up, file) {up.settings.multipart_params.id = file.id;},


FilesAdded: function(up, files) {up.start();},

FileUploaded: function(up, file, info) {
var r = $.parseJSON(info.response);
if (r.result == 'success') {
var c = $("#" + container).addClass("cf-uploader-img");
c.find(".cf-uploader-tip-c").hide();
c.find(".fileInput").val(r.file);
c.find("img").show().attr("src", ctx + r.file);
//c.find(".msg-box").empty().hide();
$('#infoForm').validator('hideMsg', c.find("input"));
}
},


Error: function(up, err) {
if (err.url) window.location.href=err.url;
}
}
}).init();
}

createUpload("cardFrontSide_container", "cardFrontSide_A");
createUpload("cardBackSideUrl_container", "cardBackSideUrl_A");
createUpload("addressProofUrl_container", "addressProofUrl_A");

var rb = $("#next").on("click", function(e) {
$("#infoForm").trigger("validate");
return false;
});

$("#infoForm").validator({
stopOnError: false,
   timely: false,
valid:function(form) {
if (rb.prop("disabled"))
            return;
//验证暂时不做
rb.prop("disabled", true).addClass("cf-disabled");
$.ajax({
               url:service + "/user/uploadInfo",
               type:"POST",
               dataType: 'json',
               data:$("#infoForm").serialize(),
               success:function(d) {
                rb.prop("disabled", false).removeClass("cf-disabled");
                if (d.status == 0) {
                d.url = ctx + "/my/line/appointment.jsp";
                }
                   if (d.status == -1)
                       msg.show().html(d.message);
                   if (d.url)
                  window.location.href=d.url; 
               },
               error:function(data) {
                   rb.prop("disabled", false).removeClass("cf-disabled");
               }
           });
}
});
});
</script>
</head>
<body id="appointmentOK">
<!--head-strat-->
<jsp:include page="/WEB-INF/portal/header1.jsp" />
<!--head-end-->
<!--main strat-->
<div class="main">
<!--注册流程编号-->
<div class="cf-register-img">
<img src="${ctxResource}/img/open-img2.png" />
</div>
<!--注册流程编号-->
<div class="cf-main-top"></div>
<div class="cf-main-cont">
<div class="cf-appointmentOk">
<form id="infoForm" method="post" autocomplete="off" >
<input type="hidden" name="id" value="${customer.id}"/>
<h2 class="cf-h2title">开通账户,需提供您的
<%if (customer.getNationtype() == 0 || customer.getNationtype() == 10) { %>
<span class="color-org">身份证</span>与<span class="color-org">住址证明</span>
<%} else { %>
<span class="color-org">护照照片</span>
<%} %>
</h2>
<p class="cf-fontsize18 cf-txt-center">请按照以下指示进行上传</p>
<div class="cf-news-shenfen">
<h3 class="cf-h2title">上传<%=customer.getNationtype()==20?"护照":"身份证明" %>:</h3>
<p class="cf-fontsize16">所拍证件需四角齐全,字迹清晰,无反光;</p>
<%boolean hasFront = customer.getCardFrontSideUrl() != null && customer.getCardFrontSideUrl().length() > 0;%>
<div class="cf-uploader-cont <%=customer.getNationtype() != 0?"cf-uploader-zhuzhi":"" %> <%=hasFront?"cf-uploader-img":"" %>" id="cardFrontSide_container">
<input type="hidden" class="fileInput" name="cardFrontSideUrl" value="${customer.cardFrontSideUrl }" <%if(!substitute) {%> data-rule="required;" data-msg-required="请上传<%=customer.getNationtype()==20?"护照":"身份证正面" %>" <%} %>/>
<a id="cardFrontSide_A" class="cf-sfz">
<%if (hasFront) { %>
<img src="${ctx}${customer.cardFrontSideUrl}"/>
<div class="cf-uploader-tip-c" style="display: none;">
<%} else { %>
<img style="display: none;"/>
<div class="cf-uploader-tip-c">
<%} %>
<p class="cf-fontsize18">正面</p>
<p>点击上传<%=customer.getNationtype()==20?"护照":"身份证正面" %></p>
</div>
</a>
<div class="cf-uploader-ts cf-color-red">
<span class="msg-box" style="position: static;" for="cardFrontSideUrl"></span>
</div>
</div>
<%
if (customer.getNationtype() == 0) {
boolean hasBack = customer.getCardBackSideUrl() != null && customer.getCardBackSideUrl().length() > 0;
%>
<div class="cf-uploader-cont <%=hasBack?"cf-uploader-img":"" %>" id="cardBackSideUrl_container">
<input type="hidden" class="fileInput" name="cardBackSideUrl" value="${customer.cardBackSideUrl }" <%if(!substitute) {%> data-rule="required;" data-msg-required="请上传身份证反面" <%} %>/>
<a id="cardBackSideUrl_A" class="cf-sfz">
<%if (hasBack) { %>
<img src="${ctx}${customer.cardBackSideUrl}"/>
<div class="cf-uploader-tip-c" style="display: none;">
<%} else { %>
<img style="display: none;"/>
<div class="cf-uploader-tip-c">
<%} %>
<p class="cf-fontsize18">反面</p>
<p>点击上传身份证反面</p>
</div>
</a>
<div class="cf-uploader-ts cf-color-red">
<span class="msg-box" style="position: static;" for="cardBackSideUrl"></span>
</div>
</div>
<%} %>
</div>

<%if(customer.getNationtype() == 0 || customer.getNationtype() == 10) { %>
<div class="cf-news-shenfen">
<h3 class="cf-h2title">上传住址证明:</h3>
<p class="cf-fontsize16">请上传三个月内的有效住址证明,且其中的地址必须与填写资料时提交的地址一致;</p>
<%if(customer.getNationtype() == 0) {%>
<p class="cf-fontsize16 cf-color-red">Tips:  住址与身份证地址不符时需上传。</p>
<%} %>
<%boolean hasAddress = customer.getAddressProofUrl() != null && customer.getAddressProofUrl().length() > 0;%>
<div class="cf-uploader-cont cf-uploader-zhuzhi  <%=hasAddress?"cf-uploader-img":"" %>" id="addressProofUrl_container">
<input type="hidden" class="fileInput" name="addressProofUrl" value="${customer.addressProofUrl }" <%=customer.getNationtype()==10&&!substitute? "data-rule=\"required;\" data-msg-required=\"请上传住址证明\"" : ""%>/>
<a id="addressProofUrl_A" class="cf-zhuzhi">
<%if (hasAddress) { %>
<img src="${ctx}${customer.addressProofUrl}"/>
<div class="cf-uploader-tip-c" style="display: none;">
<%} else { %>
<img style="display: none;"/>
<div class="cf-uploader-tip-c">
<%} %>
<p class="cf-fontsize18">住址证明</p>
<p>点击上传住址证明</p>
</div>
</a>
<div class="cf-uploader-ts cf-color-red">
<span class="msg-box" style="position: static;" for="addressProofUrl"></span>
</div>
</div>
<div class="cf-position-top"><a target="_blank" href="${ctx}/help/askdetails.jsp?q=kfxg3">什么是住址证明?</a></div>
</div>
<%} %>

<div class="cf-btn-cont">
<input type="button" id="next" class="cf-btn cf-btn-blue" value="下一步" />
<a href="${ctx}/my/line/information.jsp" class="color-blue">返回修改资料</a>
</div>
</form>
</div>
</div>
<div class="cf-main-footer"></div>
</div>
<!--main end-->
<!--footer-strat-->
<jsp:include page="/WEB-INF/portal/footer.jsp" />
<!--footer-end-->
</body>
</html>

html+JavaScript架构 可以用在.asp .php .jsp的用户注册页面中 功能如下: 1.可以验证用户密码的安全级别并返回安全级别的等级 全部数字安全级别为低 数字+字母安全级别为中 数字+大小写字母安全级别为最高 并且密码不能为全角 或者特殊符号等 如果修改功能请修改 js下的passwordstrength.js 2.姓名验证 验证中国人的姓名 3.身份证验证根据用户提供的身份证信判断出省市,然后在判断....做到只能输入 正确的省份证信息才可以.... 判断身份证的方法比使用正则表达式更加准确详细请看 js中的 checkidcard.js 判断省份证的 js function checkIsChinese(str){ if (str.length < 2 || str.length > 15){ return "姓名长度不正确"; } var ret=true; for(var i=0;i<str.length;i++){ ret=ret && (str.charCodeAt(i)>=10000); } if (ret){ return "true"; } else{ return "请输入中文"; } } //www.jsphelp.com function parseIdCard(val) { var birthdayValue; var sexId; var sexText; if (15 == val.length) //15位身份证号码 { birthdayValue = val.charAt(6) + val.charAt(7); if (parseInt(birthdayValue) < 10) { birthdayValue = '20' + birthdayValue; } else { birthdayValue = '19' + birthdayValue; } birthdayValue = birthdayValue + '-' + val.charAt(8) + val.charAt(9) + '-' + val.charAt(10) + val.charAt(11); if (parseInt(val.charAt(14) / 2) * 2 != val.charAt(14)) { sexId = "1"; sexText = "男"; } else { sexId = "2"; sexText = "女"; } } if (18 == val.length) { //18位身份证号码 birthdayValue = val.charAt(6) + val.charAt(7) + val.charAt(8) + val.charAt(9) + '-' + val.charAt(10) + val.charAt(11) + '-' + val.charAt(12) + val.charAt(13); if (parseInt(val.charAt(16) / 2) * 2 != val.charAt(16)) { sexId = "1"; sexText = "男"; } else { sexId = "2"; sexText = "女"; } } //年龄 var dt1 = new Date(birthdayValue.replace("-", "/")); var dt2 = new Date(); var age = dt2.getFullYear() - dt1.getFullYear(); var m = dt2.getMonth() - dt1.getMonth(); if (m < 0) age--; return new Array(birthdayValue, sexId, sexText, age); } function checkIdcard(idcard){ idcard = idcard.toUpperCase(); var Errors=new Array("true","身份证号码位数不对!","身份证号码出生日期超出范围或含有非法字符!","身份证号码校验错误!","身份证号码中地区编码不正确!"); var area={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:"国外"} var idcard,Y,JYM; var S,M; var idcard_array = new Array(); idcard_array = idcard.split(""); if(idcard.length != 15 && idcard.length != 18) return Errors[1]; //if(idcard.length != 18) return Errors[1]; if (idcard.substr(0,6) == "000000" || idcard.substr(0,6) == "111111" || idcard.substr(0,6) == "222222" || idcard.substr(0,6) == "333333" || idcard.substr(0,6) == "444444" || idcard.substr(0,6) == "555555" || idcard.substr(0,6) == "666666" || idcard.substr(0,6) == "777777" || idcard.substr(0,6) == "888888" || idcard.substr(0,6) == "999999") return Errors[4]; if (idcard.substr(0,6) == "123456" || idcard.substr(0,6) == "234567" || idcard.substr(0,6) == "345678" || idcard.substr(0,6) == "456789" || idcard.substr(0,6) == "567890" || idcard.substr(0,6) == "012345" || idcard.substr(0,6) == "543210" || idcard.substr(0,6) == "432109" || idcard.substr(0,6) == "321098" || idcard.substr(0,6) == "210987" || idcard.substr(0,6) == "109876" || idcard.substr(0,6) == "098765" || idcard.substr(0,6) == "987654" || idcard.substr(0,6) == "876543" || idcard.substr(0,6) == "765432") return Errors[4]; if (idcard.substr(0,6) == "121212" || idcard.substr(0,6) == "131313" || idcard.substr(0,6) == "141414" || idcard.substr(0,6) == "151515" || idcard.substr(0,6) == "161616" || idcard.substr(0,6) == "171717" || idcard.substr(0,6) == "181818" || idcard.substr(0,6) == "191919" || idcard.substr(0,6) == "101010") return Errors[4]; if (idcard.substr(0,6) == "212121" || idcard.substr(0,6) == "232323" || idcard.substr(0,6) == "242424" || idcard.substr(0,6) == "252525" || idcard.substr(0,6) == "262626" || idcard.substr(0,6) == "272727" || idcard.substr(0,6) == "282828" || idcard.substr(0,6) == "292929" || idcard.substr(0,6) == "202020") return Errors[4]; if (idcard.substr(0,6) == "313131" || idcard.substr(0,6) == "323232" || idcard.substr(0,6) == "343434" || idcard.substr(0,6) == "353535" || idcard.substr(0,6) == "363636" || idcard.substr(0,6) == "373737" || idcard.substr(0,6) == "383838" || idcard.substr(0,6) == "393939" || idcard.substr(0,6) == "303030") return Errors[4]; if (idcard.substr(0,6) == "414141" || idcard.substr(0,6) == "424242" || idcard.substr(0,6) == "434343" || idcard.substr(0,6) == "454545" || idcard.substr(0,6) == "464646" || idcard.substr(0,6) == "474747" || idcard.substr(0,6) == "484848" || idcard.substr(0,6) == "494949" || idcard.substr(0,6) == "404040") return Errors[4]; if (idcard.substr(0,6) == "515151" || idcard.substr(0,6) == "525252" || idcard.substr(0,6) == "535353" || idcard.substr(0,6) == "545454" || idcard.substr(0,6) == "565656" || idcard.substr(0,6) == "575757" || idcard.substr(0,6) == "585858" || idcard.substr(0,6) == "595959" || idcard.substr(0,6) == "505050") return Errors[4]; if (idcard.substr(0,6) == "616161" || idcard.substr(0,6) == "626262" || idcard.substr(0,6) == "636363" || idcard.substr(0,6) == "646464" || idcard.substr(0,6) == "656565" || idcard.substr(0,6) == "676767" || idcard.substr(0,6) == "686868" || idcard.substr(0,6) == "696969" || idcard.substr(0,6) == "606060") return Errors[4]; if (idcard.substr(0,6) == "717171" || idcard.substr(0,6) == "727272" || idcard.substr(0,6) == "737373" || idcard.substr(0,6) == "747474" || idcard.substr(0,6) == "757575" || idcard.substr(0,6) == "767676" || idcard.substr(0,6) == "787878" || idcard.substr(0,6) == "797979" || idcard.substr(0,6) == "707070") return Errors[4]; if (idcard.substr(0,6) == "818181" || idcard.substr(0,6) == "828282" || idcard.substr(0,6) == "838383" || idcard.substr(0,6) == "848484" || idcard.substr(0,6) == "858585" || idcard.substr(0,6) == "868686" || idcard.substr(0,6) == "878787" || idcard.substr(0,6) == "898989" || idcard.substr(0,6) == "808080") return Errors[4]; if (idcard.substr(0,6) == "919191" || idcard.substr(0,6) == "929292" || idcard.substr(0,6) == "939393" || idcard.substr(0,6) == "949494" || idcard.substr(0,6) == "959595" || idcard.substr(0,6) == "969696" || idcard.substr(0,6) == "979797" || idcard.substr(0,6) == "989898" || idcard.substr(0,6) == "909090") return Errors[4]; if(area[parseInt(idcard.substr(0,2))]==null) return Errors[4]; switch(idcard.length){ case 15: if ((parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){ ereg = /^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性 } else{ ereg = /^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性 } if(ereg.test(idcard)) return Errors[0]; else return Errors[2]; break; case 18: if ( parseInt(idcard.substr(6,4)) % 4 == 0 || (parseInt(idcard.substr(6,4)) % 100 == 0 && parseInt(idcard.substr(6,4))%4 == 0 )){ ereg = /^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}[0-9Xx]$/;//闰年出生日期的合法性正则表达式 } else{ ereg = /^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9Xx]$/;//平年出生日期的合法性正则表达式 } if(ereg.test(idcard)){ S = (parseInt(idcard_array[0]) + parseInt(idcard_array[10])) * 7 + (parseInt(idcard_array[1]) + parseInt(idcard_array[11])) * 9 + (parseInt(idcard_array[2]) + parseInt(idcard_array[12])) * 10 + (parseInt(idcard_array[3]) + parseInt(idcard_array[13])) * 5 + (parseInt(idcard_array[4]) + parseInt(idcard_array[14])) * 8 + (parseInt(idcard_array[5]) + parseInt(idcard_array[15])) * 4 + (parseInt(idcard_array[6]) + parseInt(idcard_array[16])) * 2 + parseInt(idcard_array[7]) * 1 + parseInt(idcard_array[8]) * 6 + parseInt(idcard_array[9]) * 3 ; Y = S % 11; M = "F"; JYM = "10X98765432"; M = JYM.substr(Y,1); if(M == idcard_array[17]) return Errors[0]; else return Errors[3]; } else return Errors[2]; break; default: return Errors[1]; break; } } function checkTwID(id){ //建立字母分数数组(A~Z) var city = new Array( 1,10,19,28,37,46,55,64,39,73,82, 2,11, 20,48,29,38,47,56,65,74,83,21, 3,12,30 ) id = id.toUpperCase(); // 使用「正规表达式」检验格式 if (id.search(/^[A-Z](1|2)\d{8}$/i) == -1) { return "身份证号码格式不对!"; } else { //将字符串分割为数组(IE必需这么做才不会出错) id = id.split(''); //计算总分 var total = city[id[0].charCodeAt(0)-65]; for(var i=1; i<=8; i++){ total += eval(id[i]) * (9 - i); } //补上检查码(最后一码) total += eval(id[9]); //检查比对码(余数应为0); if (total%10 == 0) { return "true"; } else { return "身份证号码格式不对!"; } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值