博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java生成仿银行卡的会员号
阅读量:5170 次
发布时间:2019-06-13

本文共 2507 字,大约阅读时间需要 8 分钟。

package com.shopping.test;import com.shopping.app.util.StringUtil;/*** * 生成仿银行卡的会员卡号 */public class BankNumberUtil{    private static int i = 0;    /**     * 需要传入一个前缀:6、8、9中的一个。     * 其中:6:类型1,  8:类型2, 9:类型3 【根据自己的业务定义】     * 其他则会返回异常     * @param prefix     * @return     */    public synchronized static String getBrankNumber(String prefix) {        if (StringUtil.isNotBlank(prefix)) {            if ("689".indexOf(prefix) >= 0 && prefix.length() == 1) {                String st = "666" + prefix + getUnixTime();                return st + getBankCardCheckCode(st);            } else {                System.out.println("银行卡号前缀有误");                return null;            }        } else {            System.out.println("银行卡号去前缀不能是空");            return null;        }    }    /***     * 获取当前系统时间戳 并截取     */    private synchronized static String getUnixTime(){        try {            Thread.sleep(10);//线程同步执行,休眠10毫秒 防止卡号重复        } catch (InterruptedException e) {            e.printStackTrace();        }        i++;i=i>100?i%10:i;        return ((System.currentTimeMillis()/100)+"").substring(1)+(i%10);    }    /**     * 校验银行卡卡号     * @param cardId     */    public static boolean checkBankCard(String cardId) {        char bit = getBankCardCheckCode(cardId.substring(0, cardId.length() - 1));        if(bit == 'N'){            return false;        }        return cardId.charAt(cardId.length() - 1) == bit;    }    /**     * 从不含校验位的银行卡卡号采用 Luhm 校验算法获得校验位     * @param nonCheckCodeCardId     * @return     */    public static char getBankCardCheckCode(String nonCheckCodeCardId) {        if (nonCheckCodeCardId == null || nonCheckCodeCardId.trim().length() == 0                || !nonCheckCodeCardId.matches("\\d+")) {            //如果传的不是数据返回N            return 'N';        }        char[] chs = nonCheckCodeCardId.trim().toCharArray();        int luhmSum = 0;        for (int i = chs.length - 1, j = 0; i >= 0; i--, j++) {            int k = chs[i] - '0';            if (j % 2 == 0) {                k *= 2;                k = k / 10 + k % 10;            }            luhmSum += k;        }        return (luhmSum % 10 == 0) ? '0' : (char) ((10 - luhmSum % 10) + '0');    }    public static void main(String[] args) {        for (int i=0;i<100;i++){            System.out.println(getBrankNumber("8"));            System.out.println(getBrankNumber("6"));            System.out.println(getBrankNumber("9"));        }    }}

 

其实就是随机时间戳+随机数+业务代码

 

转载于:https://www.cnblogs.com/wyf-love-dch/p/11379316.html

你可能感兴趣的文章
HashMap底层实现原理/HashMap与HashTable区别/HashMap与HashSet区别
查看>>
深度学习之前馈神经网络(前向传播和误差反向传播)
查看>>
IEnumerable<T>和IQueryable<T>区别
查看>>
(转)MFC界面风格
查看>>
Centos7 tmux1.6 安装
查看>>
二叉树(三)
查看>>
linux加密文件系统 fsck 无法修复一例
查看>>
【linux配置】VMware安装Redhat6.5
查看>>
AI自主决策——有限状态机
查看>>
iframe父子窗口取值
查看>>
利用Python进行数据分析_Pandas_数据结构
查看>>
《计算机组成原理》第6章:总线
查看>>
关于String str =new String("abc")和 String str = "abc"的比较
查看>>
Android软件架构及子系统介绍
查看>>
Java命名规范
查看>>
小学生算术
查看>>
BZOJ2823: [AHOI2012]信号塔
查看>>
mysql查询前几条记录
查看>>
java二分法查找实现代码
查看>>
体系编程、SOC编程那些事儿
查看>>