日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

POS DES MAC 算法

發布時間:2025/5/22 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 POS DES MAC 算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

DES和MAC加解密算法,已經在多個產品中得到了實際應用,不需任何修改就可使用

本文根據《中國銀聯直聯POS終端規范》的闡述,用C語言編程實現,該算法在實際的商業POS終端中使用。POS終端采用ECB的加密方式,簡述如下:
a) 將欲發送給POS中心的消息中,從消息類型(MTI)到63域之間的部分構成MAC?
ELEMEMENT BLOCK (MAB)。
b) 對MAB,按每8個字節做異或(不管信息中的字符格式),如果最后不滿8個字節,則添加“0X00”。
示例 :
MAB = M1 M2 M3 M4
其中:?
M1 = MS11 MS12 MS13 MS14 MS15 MS16 MS17 MS18
M2 = MS21 MS22 MS23 MS24 MS25 MS26 MS27 MS28
M3 = MS31 MS32 MS33 MS34 MS35 MS36 MS37 MS38
M4 = MS41 MS42 MS43 MS44 MS45 MS46 MS47 MS48

按如下規則進行異或運算:
MS11 MS12 MS13 MS14 MS15 MS16 MS17 MS18
XOR) MS21 MS22 MS23 MS24 MS25 MS26 MS27 MS28
---------------------------------------------------
TEMP BLOCK1 = TM11 TM12 TM13 TM14 TM15 TM16 TM17 TM18

然后,進行下一步的運算:
TM11 TM12 TM13 TM14 TM15 TM16 TM17 TM18
XOR) MS31 MS32 MS33 MS34 MS35 MS36 MS37 MS38
---------------------------------------------------
TEMP BLOCK2 = TM21 TM22 TM23 TM24 TM25 TM26 TM27 TM28

再進行下一步的運算:
TM21 TM22 TM23 TM24 TM25 TM26 TM27 TM28
XOR) MS41 MS42 MS43 MS44 MS45 MS46 MS47 MS48
---------------------------------------------------
RESULT BLOCK = TM31 TM32 TM33 TM34 TM35 TM36 TM37 TM38

c) 將異或運算后的最后8個字節(RESULT BLOCK)轉換成16 個HEXDECIMAL:
RESULT BLOCK = TM31 TM32 TM33 TM34 TM35 TM36 TM37 TM38
= TM311 TM312 TM321 TM322 TM331 TM332 TM341 TM342 ||
TM351 TM352 TM361 TM362 TM371 TM372 TM381 TM382

d) 取前8 個字節用MAK加密:
ENC BLOCK1 = eMAK(TM311 TM312 TM321 TM322 TM331 TM332 TM341 TM342)
= EN11 EN12 EN13 EN14 EN15 EN16 EN17 EN18

e) 將加密后的結果與后8 個字節異或:
EN11 EN12 EN13 EN14 EN15 EN16 EN17 EN18
XOR) TM351 TM352 TM361 TM362 TM371 TM372 TM381 TM382
------------------------------------------------------------
TEMP BLOCK= TE11 TE12 TE13 TE14 TE15 TE16 TE17 TE18

f) 用異或的結果TEMP BLOCK 再進行一次單倍長密鑰算法運算。
ENC BLOCK2 = eMAK(TE11 TE12 TE13 TE14 TE15 TE16 TE17 TE18)
= EN21 EN22 EN23 EN24 EN25 EN26 EN27 EN28

g) 將運算后的結果(ENC BLOCK2)轉換成16 個HEXDECIMAL:
ENC BLOCK2 = EN21 EN22 EN23 EN24 EN25 EN26 EN27 EN28
= EM211 EM212 EM221 EM222 EM231 EM232 EM241 EM242 ||
EM251 EM252 EM261 EM262 EM271 EM272 EM281 EM282
示例 :
ENC RESULT= %H84, %H56, %HB1, %HCD, %H5A, %H3F, %H84, %H84
轉換成16 個HEXDECIMAL:
“8456B1CD5A3F8484”
h) 取前8個字節作為MAC值。
取”8456B1CD”為MAC值。

Java代碼??
  • 數據報文:??
  • 0x?1234567890ABCDEFABCDEF1234567890???//$body??
  • MAK:2222222222222222??
  • Mac計算:??
  • M1?=?0x?1234567890ABCDEF???
  • M2?=?0x?ABCDEF1234567890??
  • M1?Xor?M2?結果:?0x?B9F9B96AA4FDB57F??
  • 擴展成16字節數據:0x?42394639423936414134464442353746??
  • MAK加密前半部分數據結果:0x?9FDE90A34CF73B2E??
  • 加密結果與后半部分數據異或,結果:0x?DEEAD6E70EC20C68??
  • MAK加密異或結果:0x?E267B6E21913D339??
  • 擴展成16字節數據:0x45323637423645323139313344333339??
  • Mac:E267B6E2??
  • php mac

    Java代碼??
  • public?function?splitData($hexMacDataSource,?$num=16)??
  • {??
  • ????$len?=?0;??
  • ??
  • ????$modValue?=?strlen($hexMacDataSource)?%?$num;??
  • ????if($modValue?!=?0)??
  • ????{??
  • ????????$hexSrcDataLen?=?strlen($hexMacDataSource);??
  • ????????$totalLen?=?$hexSrcDataLen?+?($num?-?$modValue);??
  • ????????$hexMacDataSource?=?str_pad($hexMacDataSource,?$totalLen,?"0");//16進制右補0??
  • ????}??
  • ??
  • ????$len?=?strlen($hexMacDataSource)?/?$num;??
  • ????$ds?=?array();??
  • ??
  • ????for?($i?=?0;?$i?<?$len;?$i++)??
  • ????{??
  • ????????if?(strlen($hexMacDataSource)?>=?$num)??
  • ????????{??
  • ????????????$ds[]?=?substr($hexMacDataSource,0,?$num);??
  • ????????????$hexMacDataSource?=?substr($hexMacDataSource,$num);??
  • ????????}?else??
  • ????????{??
  • ????????????throw?new?Exception("填充的數據非法!",6008);??
  • ????????}??
  • ????}??
  • ????return?$ds;??
  • }??
  • ??
  • public?function?hexXor($hexStr1?,?$hexStr2)??
  • {??
  • ????return?str_pad(strtoupper(gmp_strval(gmp_xor(gmp_init($hexStr1,?16),gmp_init($hexStr2,?16)),?16)),16,'0',STR_PAD_LEFT);??
  • }??
  • ??
  • public?function?getBodyMac($body)??
  • {??
  • ????//拆分MAC數據源,每組16位hex(8?byte())??
  • ????$ds?=?$this->splitData($body);??
  • ????$des?=?"";??
  • ????for?($i?=?0;?$i?<?count($ds);?$i++)??
  • ????{??
  • ????????if?($i?==?0)??
  • ????????{??
  • ????????????$des?=?$ds[$i];//$ds[$i]?是16進制數??
  • ????????}?else??
  • ????????{??
  • ????????????$des?=?$this->hexXor($des,?$ds[$i]);??
  • ????????}??
  • ????}??
  • ????#異或結果擴展成?16字節?的?hex??
  • ????$hexStr16?=?$this->encodeHex($des);??
  • ????#加密前8字節數據??
  • ????$left8??=?substr($hexStr16,0,16);??
  • ????$right8?=?substr($hexStr16,16,16);??
  • ????$tmpXor?=?$this->hexXor($this->encryptByDes($left8,$this->macKey),?$right8);??
  • ????$bodyMac?=??substr($this->encryptByDes($tmpXor,$this->macKey),0,8);??
  • ??
  • ????return?$bodyMac;??
  • }??
  • ??
  • public?function?encodeHex($str)??
  • {??
  • ????return?strtoupper(bin2hex($str));??
  • }??
  • #開始4個字節報文長度
    $requestBodyLength = intval(trim(substr($request, 0, 4)));
    $body = substr($request, 4, $requestBodyLength);
    #報文體
    $requestBody = substr($body, 0, $requestBodyLength - 8);
    #最后8個字節為mac
    $requestMac = substr($body, -8);

    總結

    以上是生活随笔為你收集整理的POS DES MAC 算法的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。