java车架前面的螺孔是干吗的_JAVA匹配车架号以及生成虚拟车架号

最近因为做车贷以及车险的项目接触到了车架号VIN这一个对象,在关于车辆的开发代码中,经常有要求对车架号是否合法进行判断,此前有在网上参考其他博客,只看到C++写的识别,故特地写一篇Java识别代码笔记,以免自己忘记。

在此先贴上C语言所写的博客地址:http://blog.csdn.net/tutb12345/article/details/61415148

有关车辆VIN的介绍,以及车架号的加权算法可参考该博客。

分隔线

分隔线

首先,在工具类中,定义固定的数组。

/**车架号地区代码数组*/

public static final String areaArray[] = new String[]{"1", "2", "3", "6", "9", "J", "K", "L", "R", "S", "T", "V", "W", "Y", "Z", "G"};

/**车架号中可能出现的字符数组*/

public static final String charArray[] = new String[]{"1", "2", "3", "4", "5", "6", "7", "8", "A", "B", "C", "D", "E", "F", "G", "H", "J", "K", "L", "M", "N", "P", "R", "S", "T", "V", "W", "X", "Y"};

/**车架号校验位计算数组*/

public static final Object[][] KVMACTHUP = new Object[][]{{'A', 1}, {'B', 2}, {'C', 3}, {'D', 4}, {'E', 5}, {'F', 6},{'G', 7}, {'H', 8}, {'I', 0}, {'J', 1}, {'K', 2}, {'L', 3},{'M', 4}, {'N', 5}, {'O', 0}, {'P', 7}, {'Q', 8}, {'R', 9}, {'S', 2}, {'T', 3}, {'U', 4}, {'V', 5}, {'W', 6}, {'X', 7},{'Y', 8}, {'Z', 9}};

/**车架号数据加权数组*/

public static final int[] WEIGHTVALUE = new int[]{8, 7, 6, 5, 4, 3, 2, 10, 0, 9, 8, 7, 6, 5, 4, 3, 2};

根据车架号校验方法,计算合法校验位的值。

/**

* 计算车架号的校验位

* @return

*/

public String getIsuredCode(String vin) {

char[] Vin = vin.toCharArray();

int sum = 0,tempValue = 0;

char temp;

for (int i = 0; i < 17; i++) {

if (Vin[i] >= 'a' && Vin[i] <= 'z') {

temp = (char) (Vin[i] - 32);

} else if ((Vin[i] >= 'A') && (Vin[i] <= 'Z')) {

temp = Vin[i];

} else if ((Vin[i] >= '0') && (Vin[i] <= '9')) {

tempValue = Integer.parseInt(String.valueOf(Vin[i]));

temp = Vin[i];

} else {

return "ERROR";

}

if ((temp >= 'A') && (temp <= 'Z')) {

for (int j = 0; j < 26; j++) {

if (temp == KVMACTHUP[j][0]) {

tempValue = (int) KVMACTHUP[j][1];

}

}

}

sum += tempValue * WEIGHTVALUE[i];

}

int reslt = sum % 11;

if (reslt != 10) {

return String.valueOf(reslt);

} else {

return "X";

}

}

判断计算出的校验位,是否与车架号校验位相同。

/**

* 判断vin是否正确

* @param vin

* @return

*/

public boolean isVin(String vin) {

String isuredCode = getIsuredCode(vin);

if (vin.substring(8, 9).equals(isuredCode)) {

return true;

} else {

return false;

}

}

有了判断车架号是否正确的方法,我们就可以自己随机生成车架号了。

因为车架号生成有自己的规则以及不允许出现的字符,因此,所有的字符由提前准备好的数组进行随机得出。下面是具体实现的代码。

/**

* 拼接车架号

*

* @param beforeStr

* @param afterStr

* @return

*/

public String spellVin(String beforeStr, String afterStr) {

StringBuffer vinBuffer = new StringBuffer();

String preVin = vinBuffer.append(beforeStr).append("X").append(afterStr).toString();

String isuredCode = getIsuredCode(preVin);

String vin = new StringBuffer(beforeStr).append(isuredCode).append(afterStr).toString();

if (isVin(vin)) {

return vin;

} else {

return spellVin(beforeStr, afterStr);

}

}

/**

* 生成随机前缀

*

* @return

*/

public String prepareBeforeStr() {

StringBuffer stringBuffer = new StringBuffer();

stringBuffer.append("VNN");

for (int i = 0; i < 5; i++) {

stringBuffer.append(getRandomChar(areaArray));

}

return stringBuffer.toString();

}

/**

* 生成随机后缀

*

* @return

*/

public String prepareAfterStr() {

StringBuffer stringBuffer = new StringBuffer();

for (int i = 0; i < 3; i++) {

stringBuffer.append(getRandomChar(charArray));

}

stringBuffer.append(prepareNo());

return stringBuffer.toString();

}

/**

* 生成随机的生产序号

* @return

*/

public String prepareNo(){

Random random = new Random();

StringBuffer numStrBuff = new StringBuffer();

for(int i=0;i<5;i++){

numStrBuff.append(Integer.toHexString(random.nextInt(16)).toUpperCase());

}

return numStrBuff.toString();

}

/**

* 返回随机字符

* @return

*/

public String getRandomChar(Object array[]) {

return charArray[(int) (Math.random() * 100 % array.length)];

}

车架号由17位数字以及字母组成,前面是地区代码以及厂家代码(代码中称为前缀),可以自己固定,第9位为校验位(生成时先将其置位“X”),10-12位各厂家都不同(代码中称为后缀),13-17位为生产序号(代码中为自动生成的5位16进制数)。

通过上面的代码,就可以自己校验车架号,以及为测试环境提供数据了,再也不用自己到处找数据了。

将上面的代码封装,再写上一个调用方法,一个批量获取虚拟车架号的方法,就大功告成了。

/**

* 获取随机的车架号

* @return

*/

public String getRandomVin() {

String beforeStr = prepareBeforeStr();

String afterStr = prepareAfterStr();

String vin = spellVin(beforeStr, afterStr);

return vin;

}

/**

* 获取对应数量的随机车架号

* @param num

* @return

*/

public List getVinList(int num){

List vinList = new ArrayList<>();

for(int i =0;i

vinList.add(getRandomVin());

}

return vinList;

}

注:所生成的车架号均为虚拟数据,只供测试使用,无法代替真正的车架号,也无法通过车架号查询对应车型。

如果有大佬有更好的方法,欢迎留言探讨。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值