手機IMEI碼規(guī)則及算法介紹

手機IMEI碼規(guī)則

手機IMEI碼由15-17位數(shù)字組成。
·第一部分 TAC,Type Allocation Code,類型分配碼,由8位數(shù)字組成(早期是6位),是區(qū)分手機品牌和型號的編碼,該代碼由GSMA及其授權機構(gòu)分配。其中TAC碼前兩位又是分配機構(gòu)標識(Reporting Body Identifier),是授權IMEI碼分配機構(gòu)的代碼,如01為美國CTIA,35為英國BABT,86為中國TAF。
·第二部分 FAC,F(xiàn)inal Assembly Code,最終裝配地代碼,由2位數(shù)字構(gòu)成,僅在早期TAC碼為6位的手機中存在,所以TAC和FAC碼合計一共8位數(shù)字。FAC碼用于生產(chǎn)商內(nèi)部區(qū)分生產(chǎn)地代碼。
·第三部分 SNR,Serial Number,序列號,由第9位開始的6位數(shù)字組成,區(qū)分每部手機的生產(chǎn)序列號。
·第四部分 CD,Check Digit,驗證碼,由前14位數(shù)字通過Luhn算法計算得出。
·第五部分 SVN,Software Version Number,軟件版本號,區(qū)分同型號手機出廠時使用的不同軟件版本,僅在部分品牌的部分機型中存在。


·IMEI碼貼在手機背面的標志上,并且讀寫于手機內(nèi)存中。它也是該手機在廠家的"檔案"和"身份證號"。

| TAC|TAC|TAC|TAC|TAC|TAC| FAC|FAC| SNR|SNR|SNR|SNR|SNR|SNR|SNR|
| -----|:----:|
|D14| D13|D12|D11|D10|D9|D8|D7|D6|D5|D4|D3|D2|D1|D0
|3 |5 |3 |1 |1 |4 |0 |0 |8 |0 |9 |6 |3 |6 |6

·計算IMEI驗證碼的步驟:
·1、把IMEI的奇數(shù)位數(shù)*2,如:D1,D3,D5,……D13
D13 D11 D9 D7 D5 D3 D1
10 2 8 0 0 12 12
·2、將計算得到的7個奇數(shù)位數(shù)字分別以個位數(shù)相加(如果得到的是個兩位數(shù),則十位和個位分別當成個位數(shù)來相加),再加上7個偶數(shù)位數(shù)字,如:D2,D4,D6……D14
3+1+0+3+2+1+8+0+0+8+0+9+1+2+3+1+2=44
·3、如果第2步計算得到的數(shù)字末位為0,則驗證碼數(shù)字為0。如果第2步計算結(jié)果末位數(shù)不是0,則以大于第2步計算結(jié)果的以0結(jié)尾的雙位整數(shù)減去第2步的計算結(jié)果,所獲得的個位數(shù)即為驗證碼。
D0 = 50 -44 =6

算法如下:

//c算法
char GetIMEICheckDigit(char *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)將奇數(shù)位數(shù)字相加(從1開始計數(shù))*/
        if ((i % 2) == 0)
        {
            vl_Sum1 = vl_Sum1 + pp_Imei[i] - '0';
        }
        else
        {
            /*(2)將偶數(shù)位數(shù)字分別乘以2,分別計算個位數(shù)和十位數(shù)之和(從1開始計數(shù))*/
            vl_Temp = (pp_Imei[i] - '0') * 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;

    /*如果得出的數(shù)個位是0則校驗位為0,否則為10減去個位數(shù) */
    if ((vl_Total % 10) == 0)
    {
        return '0';
    }
    else
    {
        return (char)(10 - (vl_Total % 10) + '0');
    }
}
-- lua算法
function getIMEICheckDigit(preImei)
    preImei      = stringToTable(preImei)
    local sum1   = 0
    local sum2   = 0
    local total  = 0
    local temp   = 0

    for i = 1, 14 do
        if ((i % 2) == 0) then
            -- 將偶數(shù)位數(shù)字分別乘以2,分別計算個位數(shù)和十位數(shù)之和(從1開始計數(shù))*/
            temp = (preImei[i] - '0') * 2
            if temp < 10 then
                sum2 = sum2 + temp
            else
                sum2 = sum2 + 1 + temp - 10
            end
        else
            -- 將奇數(shù)位數(shù)字相加(從1開始計數(shù))*/
            sum1 = sum1 + preImei[i] - '0'
        end
    end

    total = sum1 + sum2

    -- 如果得出的數(shù)個位是0則校驗位為0,否則為10減去個位數(shù)
    if ((total % 10) == 0) then
        return '0'
    else
        return tostring(10 - (total % 10) + '0')
    end
end

參考文獻:http://www.imeidb.com/imei-structure

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容