2024年3月30日发(作者:)
“Diebold XFS服务”源代码级深入解析
这篇文章的目的是记录一下我分析“Diebold XFS服务”软件是怎样实现的过程。当
然,我是没有Diebold软件的源代码的,也没看过一句我所分析内容涉及到的代码,其源
代码只在国外才有,我手中只有执行程序,不过,一个软件有没有源代码对于我来说是无
关紧要的,面对着计算机这个东西,我只看到代表0和1的高低电平在机器里面跳跃着,
在总线、硬盘、内存之间不停的忙碌着,其实它们与人类的世界并没有什么分别。
如果你对Diebold XFS服务是怎样实现的感兴趣的话,可以看看,不过估计能够基本
看懂这篇文章的人极少。因为本来熟悉ATM平台软件编写的人就少,再者熟悉Diebold
软件的人也少,而这两者都熟悉的人在中国不会再找到了。不过,如果你有足够的技术基
础和ATM行业知识的话,这篇文章应该对你会有些帮助的。
你要是接触过Diebold的机器,那么对于我在下文中提到的东西应该非常熟悉了,虽
然你从来没有去想过在“Diebold XFS服务”背后,它都做了些什么工作。
(本文假设大家对ATM的相关标准都比较熟悉,不专门解释文中出现的每个术语)
我这次是分析基于Windows平台下面的符合CEN/XFS标准2.0版(其实3.0基本不
变)的Diebold软件,不管以前在OS/2下面常用的TCS 912等系统。下面提到的底层都
指Windows平台的底层,一般被迪堡称为Agilis Power平台。
因为Diebold在Windows平台下面的软件都是符合WOSA/XFS标准的,所以分为
两个大部分,一个属于XFS Manager上面的一层,对应的业界标准一般是ActiveXFS规
范,另外一个属于XFS Manager下面的一层,俗称SP,对应业界的WOSA/XFS规范。
“Diebold XFS服务”是XFS Manager上面的一层,但是它却跟其他上层模块没有
太大关系。
如果接触过Diebold软件的人都知道,Diebold机器上要想运行ATM软件,首先是
启动一个Windows系统服务,叫做Diebold XFS。启动的方式就是打开在“控制面板”
里面的“服务”,找到叫做Diebold XFS的一项服务,然后鼠标点击“启动”即可。正常
生产上运行的机器,这项服务都被设置为“自动启动”,只要操作系统一起来,服务就会启
动了。
Diebold XFS是整个Diebold的程序入口处,是第一个启动的主要程序,由它来启动
其他的东西,包括初始化硬件等工作。其实Diebold XFS只是“服务”中的一个名字,对
应的程序是“C:”,启动了Diebold XFS仅仅是将
执行起来了。
既然这么重要,我们先从它看起。依赖几个非操作系
统自带的文件分别是“C:”、
“C:”,“C:windowssystem32XFS_”。
其中XFS_没什么可说的,是XFS Manager自己的三个DLL之一,主要是用
来访问注册表的,包括WFMOpenKey等函数,在这里主要是要访问注
册表中的有关SP配置的项,所以用到了XFS_。
是非常重要的dll,它就是导出SPI接口的SP程序,该dll导出了
WOSA/XFS规范规定的WFPOpen、WFPClose等SPI。但是除了导出SPI之外,
还导出了其他Diebold自用的接口,对于来说,只用了


发布评论