mac算法Java實現(xiàn)的理解

概念理解

mac算法是(Message Authentication Codes 消息認(rèn)證碼算法)长踊,是含有密鑰散列函數(shù)算法倘待。主要通過異或運算侯繁,再配合其他加密算法實現(xiàn)mac值的運算挂据,用于校驗以清。

實現(xiàn)方式

  1. 將要計算的數(shù)據(jù)通過轉(zhuǎn)換成16進(jìn)制字符串
    如:
    數(shù)據(jù):woshiceshishujuwoshiceshishujuwoshiceshishuju
    轉(zhuǎn)成16進(jìn)制:
    776F73686963657368697368756A75776F73686963657368697368756A75776F73686963657368697368756A75
  2. 根據(jù)一定的規(guī)則補位,用于下一步的分組做準(zhǔn)備,一般保證長度為16的倍數(shù)
    補位規(guī)則一般為對16進(jìn)制數(shù)據(jù)字符串長度進(jìn)行mod16取余崎逃,如果為0掷倔,直接在數(shù)據(jù)后邊拼16位的"0000000000000000",如果補位0个绍,規(guī)則就要前后端協(xié)調(diào)一致了勒葱,有的在后邊先拼接"80"然后拼"00",有的直接拼"00"
    補位后的數(shù)據(jù):
    776F7368 69636573 68697368 756A7577 6F736869 63657368 69736875 6A75776F 73686963 65736869 7368756A 75000000
  3. 將補位后的數(shù)據(jù)分組
    一般16位一組,并將每組數(shù)據(jù)保存在一個數(shù)組中
    分組后的數(shù)據(jù):
第0組明文:776F7368 69636573
第1組明文:68697368 756A7577
第2組明文:6F736869 63657368
第3組明文:69736875 6A75776F
第4組明文:73686963 65736869
第5組明文:7368756A 75000000
  1. 將分組數(shù)據(jù)進(jìn)行異或運算
第0組明文:       776F7368 69636573
第1組明文:       68697368 756A7577
第1組異或結(jié)果(第0組與第1組明文異或):   1F060000 1C091004
第2組明文:       6F736869 63657368
第2組異或結(jié)果(第1組異或結(jié)果與第2組明文異或):   70756869 7F6C636C
第3組明文:       69736875 6A75776F
第3組異或結(jié)果(第2組異或結(jié)果與第3組明文異或):   1906001C 15191403
第4組明文:       73686963 65736869
第4組異或結(jié)果(第3組異或結(jié)果與第4組明文異或):   6A6E697F 706A7C6A
第5組明文:        7368756A 75000000
與第4組密文異或:  19061C15 056A7C6A
  1. 搭配其他加密算法進(jìn)行加密計算
    這個地方可以選擇的加密算法也有很多(如:3Dex巴柿、AES凛虽、RSA等)
將最后結(jié)果轉(zhuǎn)成16進(jìn)制 31393036 31433135 30353641 37433641

將前8個字節(jié)的數(shù)據(jù)進(jìn)行加密(加密算法根據(jù)自己需求)
前8字節(jié)加密結(jié)果:  613A342B ED50BC09
與后8字節(jié)異或結(jié)果:510F026A DA138A48
再加密結(jié)果:        3550F588 19AA72AE
將最后結(jié)果轉(zhuǎn)成16進(jìn)制 33353530 46353838 31394141 37324145

前8字節(jié)作為MAC:  33353530 46353838
MAC(字符串形式):3550F588

代碼實現(xiàn)

  1. 將要計算的數(shù)據(jù)通過轉(zhuǎn)換成16進(jìn)制字符串
    如:
    數(shù)據(jù):woshiceshishujuwoshiceshishujuwoshiceshishuju
    轉(zhuǎn)成16進(jìn)制:
StringBuffer hex = new StringBuffer();  
try {  
     byte[] bs = asc.toUpperCase().getBytes("UTF-8");  
     for (byte b : bs) {  
                hex.append(Integer.toHexString(new Byte(b).intValue()));  
     }  
} catch (UnsupportedEncodingException e) {  
     e.printStackTrace();  
}  
return hex.toString();
  1. 根據(jù)一定的規(guī)則補位,用于下一步的分組做準(zhǔn)備,一般保證長度為16的倍數(shù)
int len = data.length();  
int arrLen = len / 16 + 1;  
String[] D = new String[arrLen];  
if (len % 16 == 0) {  
    data += "0000000000000000";  
} else {  
    data += "00";  
    for (int i = 0; i < 15 - len % 16; i++) {  
        data += "00";  
    }  
}
  1. 將補位后的數(shù)據(jù)分組
    一般16位一組广恢,并將每組數(shù)據(jù)保存在一個數(shù)組中
    分組后的數(shù)據(jù):
for (int i = 0; i < arrLen; i++) {  
    D[i] = data.substring(i * 16, i * 16 + 16);  
}
  1. 將分組數(shù)據(jù)進(jìn)行異或運算
String I = xOr(D[0], vector);  
String O = null;  
String kl = key.substring(0, 16);  
for (int i = 1; i < arrLen; i++) {  
//有的會在每次異或前對上次異或的結(jié)果進(jìn)行一次加密凯旋,再進(jìn)行下次異或
//      O = DES_1(I, kl, 0); 
    String str = D[i];
    I = xOr(D[i], I);  
}
public static String xOr(String s1, String s2) {  
    int[] iArr = diffOr(string2Binary(s1), string2Binary(s2));  
    return binary2ASC(intArr2Str(iArr));  
}
public static int[] diffOr(int[] source1, int[] source2) {  
    int len = source1.length;  
    int[] dest = new int[len];  
    for (int i = 0; i < len; i++) {  
        dest[i] = source1[i] ^ source2[i];  
    }  
    return dest;  
}
  1. 搭配其他加密算法進(jìn)行加密計算
    這個地方可以選擇的加密算法也有很多(如:3Dex、AES、RSA等)
String hex = ASC_2_HEX(I);
String tep1 = hex.substring(0, hex.length()/2);
String tep2 = hex.substring(hex.length()/2, hex.length());
I = DES_3(tep1, key, HEX);
I = xOr(I, tep2);
I = DES_3(I, key, 0);

此處的DES_3()是一個3DES加密算法的實現(xiàn)至非。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末钠署,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子荒椭,更是在濱河造成了極大的恐慌谐鼎,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,000評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件趣惠,死亡現(xiàn)場離奇詭異狸棍,居然都是意外死亡,警方通過查閱死者的電腦和手機味悄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評論 3 399
  • 文/潘曉璐 我一進(jìn)店門隔缀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人傍菇,你說我怎么就攤上這事猾瘸。” “怎么了丢习?”我有些...
    開封第一講書人閱讀 168,561評論 0 360
  • 文/不壞的土叔 我叫張陵牵触,是天一觀的道長。 經(jīng)常有香客問我咐低,道長揽思,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,782評論 1 298
  • 正文 為了忘掉前任见擦,我火速辦了婚禮钉汗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鲤屡。我一直安慰自己损痰,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,798評論 6 397
  • 文/花漫 我一把揭開白布酒来。 她就那樣靜靜地躺著卢未,像睡著了一般。 火紅的嫁衣襯著肌膚如雪堰汉。 梳的紋絲不亂的頭發(fā)上辽社,一...
    開封第一講書人閱讀 52,394評論 1 310
  • 那天,我揣著相機與錄音翘鸭,去河邊找鬼滴铅。 笑死,一個胖子當(dāng)著我的面吹牛就乓,可吹牛的內(nèi)容都是我干的汉匙。 我是一名探鬼主播譬淳,決...
    沈念sama閱讀 40,952評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼盹兢!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起守伸,我...
    開封第一講書人閱讀 39,852評論 0 276
  • 序言:老撾萬榮一對情侶失蹤绎秒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后尼摹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體见芹,經(jīng)...
    沈念sama閱讀 46,409評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,483評論 3 341
  • 正文 我和宋清朗相戀三年蠢涝,在試婚紗的時候發(fā)現(xiàn)自己被綠了玄呛。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,615評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡和二,死狀恐怖徘铝,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情惯吕,我是刑警寧澤惕它,帶...
    沈念sama閱讀 36,303評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站废登,受9級特大地震影響淹魄,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜堡距,卻給世界環(huán)境...
    茶點故事閱讀 41,979評論 3 334
  • 文/蒙蒙 一甲锡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧羽戒,春花似錦缤沦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至缩多,卻和暖如春呆奕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背衬吆。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評論 1 272
  • 我被黑心中介騙來泰國打工梁钾, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人逊抡。 一個月前我還...
    沈念sama閱讀 49,041評論 3 377
  • 正文 我出身青樓姆泻,卻偏偏與公主長得像零酪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子拇勃,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,630評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 這篇文章主要講述在Mobile BI(移動商務(wù)智能)開發(fā)過程中四苇,在網(wǎng)絡(luò)通信、數(shù)據(jù)存儲方咆、登錄驗證這幾個方面涉及的加密...
    雨_樹閱讀 2,475評論 0 6
  • 國家電網(wǎng)公司企業(yè)標(biāo)準(zhǔn)(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 11,005評論 6 13
  • 2017年來的如此突然月腋,我似乎是期待已久,但好像又完全沒有準(zhǔn)備好瓣赂。 我們是不該準(zhǔn)備好再出發(fā)的榆骚,生活總是充滿了意外,...
    muziyue閱讀 224評論 0 0
  • 相顧無言煌集,我多想要你的挽留妓肢。可是你懂嗎苫纤?
    開水奶茶開水閱讀 166評論 0 1
  • NimbleDroid 官網(wǎng):https://nimbledroid.com/ 一碉钠、NimbleDroid 是什么...
    路Promenade閱讀 2,430評論 0 4