IMEI 码的校验和生成
文章目录
- IMEI 码的校验和生成
- IMEI 码
- Luhn算法
- 代码实现C
IMEI 码
IMEI 码,即手机的串号。它是 International Mobile Equipment Identity( 国际移动设备身份) 的简称,就像是手机的身份证,是用来帮助辨别手机身份真伪的。
第一部分 TAC,Type Allocation Code,类型分配码,由8位数字组成(早期是6位), 是区分手机品牌和型号的编码,该代码由GSMA及其授权机构分配。其中TAC码前两位又是分配机构标识 (Reporting Body Identifier),是授权IMEI码分配机构的代码,如01为美国CTIA,35为英国BABT,86为中国TAF。
第二部分 FAC,Final Assembly Code,最终装配地代码,由2位数字构成, 仅在早期TAC码为6位的手机中存在,所以TAC和FAC码合计一共8位数字。FAC码用于生产商内部区分生产地代码。
第三部分 SNR,Serial Number,序列号,由第9位开始的6位数字组成,区分每部手机的生产序列号。
第四部分 CD,Check Digit,验证码,由前14位数字通过 Luhn算法计算得出。
第五部分 SVN,Software Version Number,软件版本号, 区分同型号手机出厂时使用的不同软件版本,仅在部分品牌的部分机型中存在。
MEI码由GSM(Global System for Mobile Communications,全球移动通信协会)统一分配,授权BABT(British approvals Board of Telecommunications,英国通信认证管理委员会)审受。
在TS.06 IMEI Allocation and Approval Process中规定IMEI校验应该通过Luhn算法计算,如下图所示:
Luhn算法
代码实现C
//返回iemi第15位校验位
uint8_t MainWindow:: GetIMEICheckDigit(uint8_t *pp_Imei)
{int i;int vl_Sum1 = 0, vl_Sum2 = 0, vl_Total = 0;int vl_Temp = 0;for (i = 0; i<14; i++){/*(1)将奇数位数字相加(从1开始计数)*/if ((i % 2) == 0){vl_Sum1 = vl_Sum1 + pp_Imei[i] ;}else{/*(2)将偶数位数字分别乘以2,分别计算个位数和十位数之和(从1开始计数)*/vl_Temp = (pp_Imei[i]) * 2;if (vl_Temp < 10){vl_Sum2 = vl_Sum2 + vl_Temp;}else{vl_Sum2 = vl_Sum2 + 1 + vl_Temp - 10;}}}/*(1)+(2)*/vl_Total = vl_Sum1 + vl_Sum2;/*如果得出的数个位是0则校验位为0,否则为10减去个位数 */if ((vl_Total % 10) == 0){return 0;}else{return (10 - (vl_Total % 10) );}
}
Qt 程序实现界面:
软件下载地址:
https://download.csdn.net/download/qq_21291397/38389253