Vin验证工具类

验证vin合法性。
写接口时需要验证vin的合法性,遂修修改改弄了一个vin验证类,放到工程中可以直接使用。

package vin.youxinpai.com;
import java.util.HashMap;
import java.util.Map;

public class VinUtil {
     public static Map<Character, Integer> kv = new HashMap<>();

        public static Map<Integer, Integer> wv = new HashMap<>();

        static {
            for (int i = 0; i < 10; i++) {
                kv.put(String.valueOf(i).charAt(0), i);
            }

            kv.put('a', 1);
            kv.put('b', 2);
            kv.put('c', 3);
            kv.put('d', 4);
            kv.put('e', 5);
            kv.put('f', 6);
            kv.put('g', 7);
            kv.put('h', 8);
            kv.put('j', 1);
            kv.put('k', 2);
            kv.put('l', 3);
            kv.put('m', 4);
            kv.put('n', 5);
            kv.put('p', 7);
            kv.put('q', 8);
            kv.put('r', 9);
            kv.put('s', 2);
            kv.put('t', 3);
            kv.put('u', 4);
            kv.put('v', 5);
            kv.put('w', 6);
            kv.put('x', 7);
            kv.put('y', 8);
            kv.put('z', 9);

            wv.put(1, 8);
            wv.put(2, 7);
            wv.put(3, 6);
            wv.put(4, 5);
            wv.put(5, 4);
            wv.put(6, 3);
            wv.put(7, 2);
            wv.put(8, 10);
            wv.put(10, 9);
            wv.put(11, 8);
            wv.put(12, 7);
            wv.put(13, 6);
            wv.put(14, 5);
            wv.put(15, 4);
            wv.put(16, 3);
            wv.put(17, 2);

        }

        public final static boolean isLegalVin(String vin) {
            if (null == vin) {
                return false;
            } else if (vin.trim().length() == 17) {
                vin = vin.trim().toLowerCase();
                char[] codes = vin.toCharArray();

                int resultInCode = 0;
                if ("0123456789".contains(vin.subSequence(8, 9))) {
                    resultInCode = Integer
                            .valueOf(vin.subSequence(8, 9).toString());
                } else {
                    if ("x".equals(vin.subSequence(8, 9))) {
                        resultInCode = 10;
                    }else{
                        return false;
                    }
                }

                int total = 0;
                for (int i = 1; i < codes.length + 1; i++) {
                    char code = codes[i - 1];

                    if (kv.containsKey(code)) {
                        if (9 == i) {
                            continue;
                        } else {
                            total += kv.get(code) * wv.get(i);
                        }
                    } else {
                        return false;
                    }
                }
                return resultInCode == total % 11;
            } else {
                return false;
            }
        }

}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值