银行卡号由最多19位数字组成。
- 前6位数字被称为发行者识别号码(Issuer Identification Number,缩写为IIN),也称为发卡行识别码(Bank Identification Number,简称BIN),常说的卡BIN就是指它,由中国银联代国内各发卡机构统一向ISO申请。6位IIN的第一位,是主要行业标识符(Major industry identifier,缩写为MII),分配如下:
- 0 - ISO/TC 68和其他行业分配
- 1 - 航空业
- 2 - 航空业,金融业和其他未来行业分配
- 3- 旅游业和娱乐业
- 4 - 银行业和金融业
- 5 - 银行业和金融业
- 6 - 商业和银行业/金融业
- 7 - 石油业和其他未来行业分配
- 8 - 医疗业,电信业和其他未来行业分配
- 9 - 由各国标准团体分配
- 中间的7~18位由发卡行自定义,表示不同的个人账户号码,最大12位;
- 最后1位是校验码,使用Luhn算法计算。
Luhn算法,也称为“模10”算法,是一种简单的校验和(Checksum)算法,一般用于验证身份识别号码,例如信用卡号码、国际移动设备识别码(International Mobile Equipment Identity,缩写为IMEI),美国供应商识别号码,加拿大社会保险号码,以色列身份证号码,希腊社会安全号码等。
Luhn算法在ISO/IEC 7812-1中定义,它不是一种安全的加密哈希函数,设计它的目的只是防止意外出错而不是恶意攻击,即我们常说的防君子不防小人。
使用Luhn算法校验的步骤:
- 从右边第1个数字(校验数字)开始偶数位乘以2;
- 把步骤1种获得的乘积的各位数字与原号码中未乘2的各位数字相加;
- 如果步骤2得到的总和模10为0,则校验通过。
举例说明:
笔者一张过期的信用卡号码为6225760008219524,根据上述步骤进行校验。
60 % 10 = 0,校验通过。大家可以据此尝试校验自己的银行卡号。
了解Lunh算法校验银行卡号的方法后,很容易推导出使用Luhn算法计算数字字符串的校验数字的方法,仍然以上述银行卡号为例,去掉校验数字后,剩余622576000821952,假设校验数字为,仍然根据上述步骤计算。
若要等式 ( 56 + ) % 10 = 0 成立,很容易得到 = 4,与实际银行卡号相符。
代码实现如下:
在金融行业软件系统中,银行卡号可谓是重要元素,但是,银行卡号本身承载的信息并不多,从上面讲述的内容来看,卡BIN是我们可以从银行卡号中获取的唯一信息,然而,卡BIN对于绝大多数人来说,使用起来并不友好,因为映射关系并不容易获取。
当然,互联网上内容包罗万象,区区卡BIN何足挂齿,网站、论坛到处都可下载,不过很多人忽略了一个问题,卡BIN是需要更新的,互联网上可以轻易下载到的卡BIN只是某个时间的快照,实效性难以保证。
笔者还看到有人提及支付宝的查询接口(ccdcapi.alipay.com/validateAnd…),笔者使用之前的过期卡号,接口返回cardType="CC"表示信用卡,bank="CMB"表示招商银行。支付宝作为国内最大的第三方支付平台,其卡BIN的准确性与实效性理论上可以得到保证,但是笔者并不清楚其卡BIN来源,估计是银行或银联。
数据从源头获取,准确性与实效性必然更胜一筹,笔者这里要推荐的卡BIN查询接口正是银联提供,银联在其开放平台(open.unionpay.com/)提供了若干接口,其中就包括了银行卡信息查询(open.unionpay.com/tjweb/api/d…)接口,该接口可以根据银行卡卡号,返回发卡行、发卡行机构代码、卡性质、卡类别、卡种、卡品牌、卡产品、卡等级、卡介质、所属总行机构中文名称、所属总行机构中文简称。
接口返回的内容可以说是相当全面了,但是笔者开发项目中并未使用过该接口,因此不能担保其性能,不过银联的权威性毋庸置疑,如需商业合作可以放心致电洽谈,银联的服务还是很专业的。
到目前为止,笔者没有看到收费标准公示,是否可以理解为仍然可以免费使用?
银联开放平台(open.unionpay.com/)同时为我们提供了另外一个优秀的接口,验证银行卡信息(open.unionpay.com/tjweb/api/d…)。我们可以通过以下5种方式进行验证,灵活组合,按需选择:
- 两要素:银行卡号+姓名
- 两要素:银行卡号+身份证号
- 三要素:银行卡号+姓名+身份证号
- 四要素:银行卡号+姓名+身份证号+银行预留手机号
- 六要素:银行卡号+姓名+身份证号+银行预留手机号+CVN2+有效期
根据个人项目经验,推荐借记卡使用四要素验证,贷记卡使用六要素验证,毕竟验证要素越多,验证就越可靠。
有了Luhn算法以及银联开放平台提供的2个接口,我们应该如何设计我们的程序(产品)呢?
-
对输入要素进行初步校验
使用Luhn算法校验银行卡号,使用上篇身份证号码的编码规则及校验介绍的公式校验身份证号。
-
银行预留手机号的校验
这里需要注意的是:银行预留手机号,有时候你认为预留了,但是可能没有预留。如果客户坚持自己填写信息无误,那么请客户致电银行查询预留手机号是解决问题的一个思路。
这里说的银行预留手机号的校验,主要是为了校验手机是否在客户本人身上,可以通过短信验证码的方式校验,其必要性:一是,从安全性出发,手机的窃取往往比银行卡相关信息的窃取成本更高;二是,毕竟银联开放平台提供的2个接口后续使用过程中极有可能都是需要收费的,一条短信的价格往往更加便宜,优先排除掉不合格的信息,从而提高后续验证的成功率。
-
调用银行卡信息查询接口
经过初步的信息校验通过,我们可以调用银联的第1个接口了,银行卡信息查询,银联返回的信息比较全面,笔者的建议是全部记录下来,当系统中积累的银行卡数据足够多的时候,通过一定的数据分析手段,恭喜你,你拥有了自己的卡BIN数据,每月更新一次,足矣。
从这个接口,可以看出银联的高明之处,它不直接告诉你卡BIN,让你每次都要调用它的接口查询,授人以渔何以授人以鱼。(大家在制定接口时,要注意:从安全性和不可替代性出发,核心数据不能泄露,尽量使用验证代替查询,这样也有利于提高接口使用率,增加用户粘性;同时,记录尽量多的请求方数据,便于日后的数据分析,也符合当前大数据的趋势。)
调用这个接口,一方面可以积累数据,另一方面可以确定客户的银行卡性质,是借记卡还是贷记卡;借记卡和贷记卡在进行验证时,验证要素略有差异,笔者开发项目过程中接触的银行卡验证,除了银行卡号、姓名、身份证号、手机号四要素之外,借记卡可以额外验证密码,贷记卡可以额外验证CVN2、有效期,目前发行的芯片借记卡也有CVN2、有效期,但是笔者项目中从来没有对此验证过,不知银联这个接口是否可以验证。
有时,为了提升客户体验,借记卡的密码,贷记卡的CVN2、有效期也不做验证。便利性与安全性是需要互相妥协的,但是它们不是鱼与熊掌,通过技术手段完全可以鱼与熊掌兼得。
- 以上就是本篇文章【银行卡号的编码规则及校验】的全部内容了,欢迎阅览 ! 文章地址:http://dfvalve.xrbh.cn/quote/419.html 行业 资讯 企业新闻 行情 企业黄页 同类资讯 网站地图 返回首页 迅博思语资讯移动站 http://keant.xrbh.cn/ , 查看更多