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值。
数据报文: 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
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);
相关推荐
【Android代码-安卓版本pos机】项目主要涵盖了在Android平台上开发的一款移动支付终端应用,它允许用户通过智能手机或平板电脑进行类似于传统POS机的交易操作。这个项目的核心目标是将传统的零售支付体验移植到移动...
POS机购物小票数字识别算法研究 本文档主要探讨了POS机购物小票数字识别算法的研究,以解决购物过程中的数字识别问题。该研究的目的是为了提高购物小票数字识别的准确率,从而满足商业和个人购物需求。 首先,论文...
POS机,全称为Point of Sale,是零售业中用于处理销售交易的重要设备。在这个压缩包中,我们看到的是POS机的源码,编程语言为C。C语言是一种基础且强大的编程语言,因其效率高、可移植性强而广泛应用于系统级编程和...
【标题】:“C++编写的简单POS机程序” 在信息技术领域,POS(Point of Sale)机是一种用于商业交易处理的设备,通常用于零售业。它能够读取商品条形码,计算总价,处理支付,并记录销售数据。在这个场景中,我们...
8210POS机是一种常见的商用电子支付终端,主要用于处理各种交易,如信用卡刷卡、借记卡支付等。在IT行业中,POS机的软件更新和维护是确保其正常运行的关键环节。"8210pos机下载软件"指的是为这种设备提供的一种软件...
【电信POS机管理】是一个基于DELPHI 7开发的小程序,主要功能是实现对电信POS设备的信息管理和数据导入。在IT行业中,POS(Point of Sale)机是一种用于销售终端的设备,通常用于处理交易,如信用卡支付。电信POS机...
在IT行业中,模拟POS机程序源码是一种用于测试和开发支付系统的重要工具。POS(Point of Sale)机是商家处理交易的终端设备,通常用于信用卡或借记卡的支付操作。这里提到的“模拟POS机程序”允许开发者在不实际接入...
本项目中的C++超市收银POS机系统是一个综合运用面向对象编程、数据结构、算法和系统设计的实例。通过C++强大的功能,我们可以构建出一个高效、可靠且功能丰富的收银系统,满足现代零售业的需求。同时,这也为学习C++...
### Linux POS机资料知识点解析 #### 一、概述 该文档提供了一份关于Linux POS机的详细资料,主要涉及POS终端设备的接口规格和技术细节。POS(Point of Sale)系统是指销售点信息系统,通常用于零售业中的商品销售和...
"模拟POS机计算MAC(基于JMeter)"是一个针对此类需求的解决方案。POS(Point of Sale)机是商家处理银行卡交易的设备,而MAC(Message Authentication Code)是一种用于验证消息完整性的密码学机制。这里我们将详细...
《C#实现8583协议在POS机程序中的应用》 8583协议,全称为ISO 8583,是国际标准化组织(ISO)制定的一种金融交易消息传输标准,广泛应用于银行、支付系统以及POS终端设备之间。这个协议定义了金融交易数据的结构和...
首先,"waterPOS.C"是压缩包中的核心源代码文件,它很可能包含了水控POS机的主要逻辑和控制算法。在C语言中编写,这种程序通常会涉及到串口通信、数据解析以及硬件控制等技术。其中,串口通信是POS机与刷卡设备交互...
在这个小型POS机系统中,我们关注的重点是其实现了进货、查询和出货的核心功能。 进货功能是POS机的基本组成部分,它涉及到商品的入库管理。在C语言版的POS机系统中,可能会包含一个模块来处理进货操作,如接收供应...
华智融作为国内知名的POS机制造商,其产品以稳定性和高效性著称。本文将围绕“华智融 POS 机 8120 最新的固件”这一主题,深入探讨固件的更新、功能以及对设备性能的影响。 首先,固件是嵌入式系统的核心组成部分,...
在这个“POS-code.rar”压缩包中,包含了使用C++编程语言开发的POS机系统的源代码,这对于理解POS机的工作原理、学习C++编程以及了解如何将两者结合具有很大的帮助。 C++是一种强大的、面向对象的编程语言,因其...
《C#技术在POS机收银系统开发中的应用深度解析》 C#,作为微软公司推出的面向对象的编程语言,以其高效、安全和强大的库支持,成为开发商业级应用程序的首选语言之一。在这个名为"C#开发的POS机收银系统"的项目中,...