python银行卡号码校验Luhn模10算法

作者:CC11001100 时间:2022-03-18 07:32:52 

有时候在网上办理一些业务时有些需要填写银行卡号码,当胡乱填写时会立即报错,但是并没有发现向后端发送请求,那么这个效果是怎么实现的呢。

对于银行卡号有一个校验算法,叫做Luhn算法。

一、银行卡号码的校验规则

银行卡号码的校验采用Luhn算法,校验过程大致如下:

1. 从右到左给卡号字符串编号,最右边第一位是1,最右边第二位是2,最右边第三位是3….

2. 从右向左遍历,对每一位字符t执行第三个步骤,并将每一位的计算结果相加得到一个数s。

3. 对每一位的计算规则:如果这一位是奇数位,则返回t本身,如果是偶数位,则先将t乘以2得到一个数n,如果n是一位数(小于10),直接返回n,否则将n的个位数和十位数相加返回。

4. 如果s能够整除10,则此号码有效,否则号码无效。

因为最终的结果会对10取余来判断是否能够整除10,所以又叫做模10算法。

校验算法比较简单,一个python的实现:

#! /usr/bin/python3
# -*- coding: utf-8 -*-
def luhn(card_num):
   s = 0
   card_num_length = len(card_num)
   for _ in range(1, card_num_length + 1):
       t = int(card_num[card_num_length - _])
       if _ % 2 == 0:
           t *= 2
           s += t if t < 10 else t % 10 + t // 10
       else:
           s += t
   return s % 10 == 0
if __name__ == '__main__':
   print(luhn('6226095711989751'))

二、生成符合Luhn规则的银行卡号测试数据

前面既然摸清了银行卡号的校验规则,那么就可以根据此规则生成一些能够通过Luhn校验的测试数据。

思路:

因为最右边的一位是奇数位,奇数位不需要改变值直接放啥就是啥,这个特性很重要,正好可以用来补齐到正好能够整除10。

所以显然能够推测出生成n位符合Luhn规则的算法:

1. 随机生成n-1位字符,称为字符串x。

2. 先假设字符串x有n位(实际上最右边一位缺失是n-1位),将x按照n位长度计算和s,因为最右边第一位是缺失的,忽略跳过,所以计算时最右边一位从2开始。

3. 上一步得到字符串x的校验和s,将s加上一个数字y,使得它正好可以整除10,这个y就是最右边第一位应该放的数字。

4. x+y做字符串拼接运算,得到最终的n位符合Luhn规则的字符串。

实现代码:

#! /usr/bin/python3
# -*- coding: utf-8 -*-
import random
def gen_card_num(start_with, total_num):
   result = start_with
   # 随机生成前N-1位
   while len(result) < total_num - 1:
       result += str(random.randint(0, 9))
   # 计算前N-1位的校验和
   s = 0
   card_num_length = len(result)
   for _ in range(2, card_num_length + 2):
       t = int(result[card_num_length - _ + 1])
       if _ % 2 == 0:
           t *= 2
           s += t if t < 10 else t % 10 + t // 10
       else:
           s += t
   # 最后一位当做是校验位,用来补齐到能够整除10
   t = 10 - s % 10
   result += str(0 if t == 10 else t)
   return result
def luhn(card_num):
   s = 0
   card_num_length = len(card_num)
   for _ in range(1, card_num_length + 1):
       t = int(card_num[card_num_length - _])
       if _ % 2 == 0:
           t *= 2
           s += t if t < 10 else t % 10 + t // 10
       else:
           s += t
   return s % 10 == 0
if __name__ == '__main__':
   for _ in range(1000):
       random_card_num = gen_card_num('622609', 16)
       valid_result = luhn(random_card_num)
       print('%s %s' % (random_card_num, valid_result))

python银行卡号码校验Luhn模10算法

三、小结

1. 在开发需要填写银行卡号的表单时,最好能够在前端加上一层Luhn校验,以将大部分的非法输入在前端就拦截过滤掉。

2. 在需要一些银行卡号测试数据时,可以使用上面的代码生成一些合法的银行卡号作为测试数据。

3.  明白了这些之后以后转账再输卡号不用那么担心了,因为如果不小心输错了一位的话能够校验出来的,当然理论上是这样的,但对于我这样的穷人十块钱以上的高额交易就得确认好几次&hellip;

相关资料

在线查询银行卡号归属信息工具 - aTool在线工具

银行卡校验规则(Luhn算法)

来源:https://www.cnblogs.com/cc11001100/p/9357177.html

标签:银行卡,号码校验,Luhn,算法
0
投稿

猜你喜欢

  • Python递归及尾递归优化操作实例分析

    2022-06-17 16:09:10
  • python 简单备份文件脚本v1.0的实例

    2022-05-01 01:47:53
  • Dreamweaver 网页编辑常用表现的实现方法

    2010-10-20 20:05:00
  • Python数据分析之双色球基于线性回归算法预测下期中奖结果示例

    2021-12-04 12:39:55
  • tensorflow 初始化未初始化的变量实例

    2021-05-16 13:47:54
  • 利用pytorch实现对CIFAR-10数据集的分类

    2021-11-21 03:09:36
  • W3C发布HTML 5草案 最终版将于2010年敲定

    2008-01-26 19:16:00
  • python 制作python包,封装成可用模块教程

    2022-06-02 06:32:25
  • Python实现Telnet自动连接检测密码的示例

    2021-10-05 11:08:37
  • python的迭代器与生成器实例详解

    2021-06-21 15:36:41
  • Python中getpass模块无回显输入源码解析

    2022-05-02 03:58:28
  • Go语言变量与基础数据类型详情

    2023-08-30 03:13:16
  • 使用MHTML 解决 data URI scheme 的浏览器兼容问题

    2009-05-11 12:30:00
  • 解决python运行启动报错问题

    2022-08-13 06:44:15
  • python 识别登录验证码图片功能的实现代码(完整代码)

    2021-03-14 23:03:40
  • python中的生成器实现周期性报文发送功能

    2023-02-07 23:15:12
  • 关于Python中*args和**kwargs的深入理解

    2021-04-07 17:45:06
  • Pycharm内置终端及远程SSH工具的使用教程图文详解

    2023-03-26 09:58:30
  • Python实现注册、登录小程序功能

    2022-12-03 17:50:11
  • Python3.7 新特性之dataclass装饰器

    2021-05-11 13:13:40
  • asp之家 网络编程 m.aspxhome.com