IMEI校验码算法:
(1).将偶数位数字分别乘以2,分别计算个位数和十位数之和
(2).将奇数位数字相加,再加上上一步算得的值
(3).如果得出的数个位是0则校验位为0,否则为10减去个位数
如:35 89 01 80 69 72 41 偶数位乘以2得到5*2=10 9*2=18 1*2=02 0*2=00 9*2=18 2*2=04 1*2=02,计算奇数位数字之和和偶数位个位十位之和,得到 3+(1+0)+8+(1+8)+0+(0+2)+8+(0+0)+6+(1+8)+7+(0+4)+4+(0+2)=63 => 校验位 10-3 = 7
package com.test.main;
public class IMEIGen {
/**
* @param args
*/
public static void main(String[] args) {
String code = "35254112521455";
String newCode = genCode(code);
System.out.println("======"+newCode);
System.out.println(code+newCode);
}
public static String genCode(String code){
int total=0,sum1=0,sum2 =0;
int temp=0;
char [] chs = code.toCharArray();
for (int i = 0; i < chs.length; i++) {
int num = chs[i] - '0'; // ascii to num
//System.out.println(num);
/*(1)将奇数位数字相加(从1开始计数)*/
if (i%2==0) {
sum1 = sum1 + num;
}else{
/*(2)将偶数位数字分别乘以2,分别计算个位数和十位数之和(从1开始计数)*/
temp=num * 2 ;
if (temp < 10) {
sum2=sum2+temp;
}else{
sum2 = sum2 + temp + 1 -10;
}
}
}
total = sum1+sum2;
/*如果得出的数个位是0则校验位为0,否则为10减去个位数 */
if (total % 10 ==0) {
return "0";
}else{
return (10 - (total %10))+"";
}
}
}
下面在附带一个EXCEL IMEI 自动生成的算法;
先把14位数据放在A2,
=A2&RIGHT((10-MOD(VALUE(MID(A2,1,1))+VALUE(MID(A2,3,1))+VALUE(MID(A2,5,1))+VALUE(MID(A2,7,1))+VALUE(MID(A2,9,1))+VALUE(MID(A2,11,1))+VALUE(MID(A2,13,1))+IF(VALUE(MID(A2,2,1))<5,VALUE(MID(A2,2,1))*2,VALUE(MID(A2,2,1))*2-9)+IF(VALUE(MID(A2,4,1))<5,VALUE(MID(A2,4,1))*2,VALUE(MID(A2,4,1))*2-9)+IF(VALUE(MID(A2,6,1))<5,VALUE(MID(A2,6,1))*2,VALUE(MID(A2,6,1))*2-9)+IF(VALUE(MID(A2,8,1))<5,VALUE(MID(A2,8,1))*2,VALUE(MID(A2,8,1))*2-9)+IF(VALUE(MID(A2,10,1))<5,VALUE(MID(A2,10,1))*2,VALUE(MID(A2,10,1))*2-9)+IF(VALUE(MID(A2,12,1))<5,VALUE(MID(A2,12,1))*2,VALUE(MID(A2,12,1))*2-9)+IF(VALUE(MID(A2,14,1))<5,VALUE(MID(A2,14,1))*2,VALUE(MID(A2,14,1))*2-9),10)),1)