mac签名值用于直连SaaS平台的终端进行请求参数认证。待签名数据用如下方法组装:排除mac参数之外,将其它参数(空值除外)按名称进行字母排序,并和它的取值一起组成name=value样式的字符串,然后用&把它们拼装为一个大字符串,对于嵌套的参数,嵌套的参数列表也需按照字母排序进行拼装。请求参数及返回参数,均采用相同机制进行签名。SAAS平台的接口可能增加字段,验证签名时必须支持增加的扩展字段

POS终端采用ECB的加密方式,简述如下:
  a) 待签名数据称为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 TM331 TM332 TM341 TM342 || TM351 TM352 TM361 TM362 TM371 TM372 TM381 TM382

d) 用MAK加密(3des):
  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 T,362 TM371 TM372 TM381 TM382


  TEMP BLOCK = TE11 TE12 TE13 TE14 TE15 TE16 TE17 TE18

f) 用异或的结果TMP BLOCK 再进行一次3des加密
  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
h) 取前8个字节作为MAC值
  MAC = EM211 EM212 EM221 EM222 EM231 EM232 EM241 EM242

文档更新时间: 2023-12-11 16:40   作者:admin