轉自:http://blog.csdn.net/fengyifei11228/article/details/45919797
IMEI是國際移動通訊設備識別號(International Mobile Equipment Identity)的縮寫,用於GSM系統。
由15位數字組成,前6位(TAC)是型號覈准號碼,代表手機類型。接着2位(FAC)是最後裝配號,代表產地。後6位(SNR)是串號,代表生產順序號。最後1位(SP)是檢驗碼。
MEID是移動通訊設備識別號(Mobile Equipment IDentifier)的縮寫,用於CDMA系統。
由15位16進制數字組成(一般使用前14位),前8位是生產商編號,後6位是串號,最後1位是檢驗碼。
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
MEID校驗碼算法:
(1).將偶數位數字分別乘以2,分別計算個位數和十位數之和,注意是16進制數
(2).將奇數位數字相加,再加上上一步算得的值
(3).如果得出的數個位是0則校驗位爲0,否則爲10(這裏的10是16進制)減去個位數
如:AF 01 23 45 0A BC DE 偶數位乘以2得到F*2=1E 1*2=02 3*2=06 5*2=0A A*2=14 C*2=18 E*2=1C,計算奇數位數字之和和偶數位個位十位之和,得到 A+(1+E)+0+2+2+6+4+A+0+(1+4)+B+(1+8)+D+(1+C)=64 => 校驗位 10-4 = C
- /**
- * IMEI是國際移動通訊設備識別號(International Mobile Equipment Identity)的縮寫,用於GSM系統。
- * 由15位數字組成,前6位(TAC)是型號覈准號碼,代表手機類型。接着2位(FAC)是最後裝配號,代表產地。後6位(SNR)是串號,代表生產順序號。最後1位(SP)是檢驗碼。
- * MEID是移動通訊設備識別號(Mobile Equipment IDentifier)的縮寫,用於CDMA系統。
- * 由15位16進制數字組成,前8位是生產商編號,後6位是串號,最後1位是檢驗碼。
- * @author fengyifei11228
- * @since 2015-05-22
- */
- public class DeviceUtil {
- /**
- * 格式化MEID
- * 因爲MEID格式不統一,長度有14位和16位的,所以,爲了統一,將14位和16位的MEID,統一設置爲15位的 設置格式:
- * 如果MEID長度爲14位,那麼直接得到第15位,如果MEID長度爲16位,那麼直接在根據後14位得到第15位
- * 如果MEID長度爲其他長度,那麼直接返回原值
- * @param meid
- * @return
- */
- public static String formatMeid(String meid) {
- int dxml = meid.length();
- if (dxml != 14 && dxml != 16) {
- return meid;
- }
- String meidRes = "";
- if (dxml == 14) {
- meidRes = meid + getmeid15(meid);
- }
- if (dxml == 16) {
- meidRes = meid.substring(2) + getmeid15(meid.substring(2));
- }
- return meidRes;
- }
- /**
- * 格式化IMEI
- * 因爲IMEI格式不統一,長度有14位和16位的,所以,爲了統一,將14位和16位的MEID,統一設置爲15位的 設置格式:
- * 如果IMEI長度爲14位,那麼直接得到第15位,如果MEID長度爲16位,那麼直接在根據前14位得到第15位
- * 如果IMEI長度爲其他長度,那麼直接返回原值
- * @param imei
- * @return
- */
- public static String formatImei(String imei) {
- int dxml = imei.length();
- if (dxml != 14 && dxml != 16) {
- return imei;
- }
- String imeiRes = "";
- if (dxml == 14) {
- imeiRes = imei + getimei15(imei);
- }
- if (dxml == 16) {
- imeiRes = imei + getimei15(imei.substring(0,14));
- }
- return imeiRes;
- }
- /**
- * 根據MEID的前14位,得到第15位的校驗位
- * MEID校驗碼算法:
- * (1).將偶數位數字分別乘以2,分別計算個位數和十位數之和,注意是16進制數
- * (2).將奇數位數字相加,再加上上一步算得的值
- * (3).如果得出的數個位是0則校驗位爲0,否則爲10(這裏的10是16進制)減去個位數
- * 如:AF 01 23 45 0A BC DE 偶數位乘以2得到F*2=1E 1*2=02 3*2=06 5*2=0A A*2=14 C*2=18 E*2=1C,
- * 計算奇數位數字之和和偶數位個位十位之和,得到 A+(1+E)+0+2+2+6+4+A+0+(1+4)+B+(1+8)+D+(1+C)=64
- * 校驗位 10-4 = C
- * @param meid
- * @return
- */
- private static String getmeid15(String meid) {
- if (meid.length() == 14) {
- String myStr[] = { "a", "b", "c", "d", "e", "f" };
- int sum = 0;
- for (int i = 0; i < meid.length(); i++) {
- String param = meid.substring(i, i + 1);
- for (int j = 0; j < myStr.length; j++) {
- if (param.equalsIgnoreCase(myStr[j])) {
- param = "1" + String.valueOf(j);
- }
- }
- if (i % 2 == 0) {
- sum = sum + Integer.parseInt(param);
- } else {
- sum = sum + 2 * Integer.parseInt(param) % 16;
- sum = sum + 2 * Integer.parseInt(param) / 16;
- }
- }
- if (sum % 16 == 0) {
- return "0";
- } else {
- int result = 16 - sum % 16;
- if (result > 9) {
- result += 65 - 10;
- }
- return (char)result + "";
- }
- } else {
- return "";
- }
- }
- /**
- * 根據IMEI的前14位,得到第15位的校驗位
- * 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
- * @param imei
- * @return
- */
- private static String getimei15(String imei){
- if (imei.length() == 14) {
- char[] imeiChar=imei.toCharArray();
- int resultInt=0;
- for (int i = 0; i < imeiChar.length; i++) {
- int a=Integer.parseInt(String.valueOf(imeiChar[i]));
- i++;
- final int temp=Integer.parseInt(String.valueOf(imeiChar[i]))*2;
- final int b=temp<10?temp:temp-9;
- resultInt+=a+b;
- }
- resultInt%=10;
- resultInt=resultInt==0?0:10-resultInt;
- return resultInt + "";
- }else{
- return "";
- }
- }
- }