zoukankan      html  css  js  c++  java
  • 移动支付[1]——MAC加密

    前段时间做了一个移动支付的项目,一直想写点什么自己积累一下,也供给遇到同样问题的朋友们参考参考.之所以先写MAC这一块是因为当时我第一个要解决的问题就是这个MAC.

    项目环境提前说一下,项目是在WinCE下的.NET项目.提前说的原因是在.NET Compact Framework里包含了DES和3DES的加解密,需要自己写DES,3DES加解密算法的时候可以参考ChenKaiHomeWindows phone应用开发[16]-数据加密一文.

    言归正转,

    MAC算法(官方文档)

    POS终端采用ECB的加密方式,简述如下:
    1、将欲发送给POS中心的消息中,从消息类型(MTI)到63域之间的部分构成MAC ELEMEMENT BLOCK
    (MAB)。
    2、对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
    3、将异或运算后的最后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
    4、取前8 个字节用MAK加密:
    ENC BLOCK1 = eMAK(TM311 TM312 TM321 TM322 TM331 TM332 TM341 TM342)
    = EN11 EN12 EN13 EN14 EN15 EN16 EN17 EN18
    5、将加密后的结果与后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
    6、用异或的结果TEMP BLOCK 再进行一次DES运算。
    ENC BLOCK2 = eMAK(TE11 TE12 TE13 TE14 TE15 TE16 TE17 TE18)
    = EN21 EN22 EN23 EN24 EN25 EN26 EN27 EN28
    7、将运算后的结果(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
    8、取前8个字节作为MAC值。
    取8456B1CD为MAC值.

    代码

    代码是从几个工具类里提出来放到这里的,显示有些不伦不类,也有些结构上需要改进的地方,欢迎现在正在做这一块的朋友们一起讨论.也可以新浪@yangyoungLive联系我.

  • 相关阅读:
    一个完整的Oracle建表的例子
    【转】oracle 体系结构
    JMeter-Window10系统下设置环境变量
    JMeter 3.0 POST Body Data 中文乱码问题
    JMeter接口测试报错,反馈和postman不一样(二)
    JMeter参数文件的相对路径
    JMeter正则表达式提取器说明
    JMeter接口测试报错,反馈和postman不一样(一)
    协程实现多边同时交互原理
    python 多线程中子线程和主线程相互通信
  • 原文地址:https://www.cnblogs.com/yangyoung/p/2520461.html
Copyright © 2011-2022 走看看