全世界95%的ATM机还在使用Windows XP

本文转载至:http://jandan.net/2014/01/19/atms-windowsxp.html

近日富国银行(WFC)、美国银行(BAC)和摩根大通(JPM)都在标榜各家ATM机上推出的一美元取款、无套封存款、邮票代售等最新功能。而ATM的内部是如何运行却没有多少人熟悉。

全世界95%的ATM机还在使用Windows XP
XP操作系统将退出ATM平台

40年前ATM(Automatic Teller Machine)走进人们生活的时候还被视作高端科技。今天人们已经不这么看了。美国共有42万台ATM机,截止今年4月8日,全美所有的ATM都被要求限期更换操作系统,整个国家的现金领取系统更新换代的真的很慢。根据之前的消息,微软正式宣布在2014年4月8日停止Windows Xp的技术支持(编者按:微软已经将日期延后至2015年7月),也就是说所有运行Windows XP操作系统的ATM机器将无法更新补丁,再也无法符合银行业标准。大多数机器将升级为Windows 7。(某些使用Windows XP 嵌入版的公司可以延缓更换,因为嵌入版不容易感染病毒,对于这部分机器,微软技术支持将持续到2016年年初。)

全世界95%的ATM机还在使用Windows XP
ATM曾经被人们视作高科技

ATM内部是一台电脑,和所有电脑一样,ATM里的电脑也有操作系统。美国最大ATM供应商NCR的市场总监Robert Johnston说,ATM市场目前被Windows XP占领,全世界95%以上ATM用电脑使用Window XP系统,在美国情况也几乎一样。

美国ATM网络过于繁杂,存在太多网点,有只有一台过时取款机的小便利店,也有监督数千台终端的国家银行,不同的网点对更换系统限期的体会也不同,ATM Marketplace网的编辑Suzanne Cluckey说。技术更高级的ATM能够联网升级操作系统,但是老式ATM机器只能一台一台手动升级,或是因为配置无法运行更新系统只能更换。“我用的银行的ATM机器看上去就像用了20年,根本没办法支持Windowns 7系统,”Cluckey说,“许多ATM机都面临要么升级要么淘汰被卖到旧货市场或者干脆当成垃圾的命运。”

全世界95%的ATM机还在使用Windows XP
ATM内部

ATM软件供应商KAL公司的首席执行官Aravinda Korala说他预计全美15%的银行ATM机将在4月前升级成Windows 7 。“ATM市场还没有做好准备,但是这并不是什么稀奇事,”他说,“ATM电脑的运行速度没有个人电脑那么快。”ATM看似无处不在,但根据咨询公司Retail Banking Research的调查,全世界只有约300万台ATM机,和全球众多的Windows用户相比,这个数字还是显得很小。业内的规则是每季度发布一次对ATM机有直接影响的安全补丁,Korala说。

微软将以前的免费XP布丁发布改向客户出售定制技术支持合约服务,此服务可以延长Windows XP操作系统的寿命,价钱方面贵了不少——第二年的服务费用是第一年的5倍。摩根大通就购买了一年期的服务,在这段时间内摩根大通会把所有ATM升级成Windwows 7系统,在今年7月之前就会全部更换完毕:在全面更新开始前,有大约3000到19000台ATM需要打补丁,摩根大通的发言人Patricia Wexler.说。富国银行发言人说公司正与微软和ATM制造商合作升级富国银行的ATM机器。

一台ATM从Windows XP升级成Windows 7的花费不一,如果硬件可以支持ATM运行Windows 7花费大致在几百美元,Stewart说,如果须要加新硬件,花费可能在几千美元。

有些ATM运营商不顾微软的最后通牒,还会继续使用XP系统,ATM设备商Diebold 的执行官Dean Stewart说。但是这些ATM的安全性将大大降低,更容易成为恶意软件和安全漏洞的攻击对象。(银行客户在银行提供的标准保护规范下,存款金还是安全的。)“这种风险是实实在在的,”Stewart说“没有那家ATM运营银行愿意自己成为被攻击目标。”

全世界95%的ATM机还在使用Windows XP
你担心存款消失么?

此前ATM行业也遇到过种种危机。“从2000年开始,银行对危机的处理就十分完善,”ATM制造商Nautilus Hyosung,的营销总监Rob Evans说到。2002年ATM强制推行新加密法。2011年全美银行升级语音功能以符合美国残疾人法案的规定。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 账户类(满分50 分) 版本1:满分10 分 设计 Account1 类,包含: ■ 一个名为id 的int 类型的私有数据域(默认值为0),长度为6 位。 ■ 一个名为balance 的double 类型的私有数据域(默认值为0)。 ■ 一个名为annualInterestRate 的double 类型的私有数据域存储当前利率(默认值为0)。 假设所有的账户都有相同的利率。 ■ 一个名为dateCreated 的Date 类型的私有数据域存储账户的开户日期。 ■ 一个能创建默认账户的无参构造方法。 ■ 一个能创建带特定id 和初始余额的构造方法,初始余额不能为负数。 ■ id、balance 和annualInterestRate 的访问器和修改器。 ■ dateCreated 的访问器。 ■ 一个名为getMonthlyInterestRate 的方法返回月利率。 ■ 一个名为withDraw 的方法从账户提取特定金额。 ■ 一个名为deposit 的方法向账户存人特定金额。 ■ double 类型的数据域保留2 位小数。 ■ 成员方法和数据域应进行基本的合理性检查。 设计测试类ATMMachine1: ■ 创建一个有100 个账户的数组,其id 为0,1,2,...99, 并初始化收支为1000 美元。 ■ 主菜单如下(可参考教材中文版P296 或英文版P367): Main menu 1: check balance 2: withdraw 3: deposit 4: exit 版本2:满分20 分 扩展 Account1 类为Account2 类: ■ Account2 类继承Account1 类。 ■ 为Account2 类新增一个名为password 的String 类型的私有数据域存储账号密码。 password 只能为字母或数字,长度不能小于6 且不能大于10。密码显示时为*******。 ■ 为Account2 类新增一个名为name 的String 类型的私有数据域存储客户名字。 ■ 为Account2 类新增一个名为transactions 的ArrayList 类型的新数据域,其为客户存 储交易记录。这要求新建一个名为Transaction 的类,类的定义请参照教材中文版P327 或英 文版P404。每笔交易都是Transaction 类的一个实例。 ■ 新增一个带初始余额的构造方法,其id 随产生,但不能与当前系统的id 重复。 若初始余额的参数为负数,则抛出一个自定义异常并在当前构造方法中进行处理。 ■ 重写方法withDraw,要求支取的金额为100 的整数倍,并且当日支取金额不能超过 5000,支取金额不允许透支。每进行一次操作应向transactions 数组线性表添加一笔交易。 ■ 重写方法deposit,要求每进行一次操作应向transactions 数组线性表添加一笔交易。 ■ 新增一个方法changePassword,只有旧密码正确,新密码符合要求,且两次输入相 同的情况下才可以成功修改密码 设计测试类ATMMachine2,其主菜单如下(可参考教材中文版P296 或英文版P367): Main menu 0:create a account 1: check balance 2: withdraw 3: deposit 4:details of the transaction 5: change password 6:exit ■ 若用户选择新建一个账号, 则应提示用户输入账号password 、balance 和 annualInterestRate,其中id 随产生。新产生的账户应序列化到名为accounts.dat 的文件中。 所有账户只能通过这种方式产生。 ■ 所有用户操作结果应同步到accounts.dat 文件中相应账户中。 ■ 所有用户操作应有友好、简介的提示语。 版本3:满分20 分 请参照银行的ATM 界面,在Account2 类的基础上开发一个GUI 界面的ATM 系统。 要求界面应模拟小键盘,并且账户信息读、写于文件accounts.dat。
1. 账户类(满分50分) 版本1:满分10 分 设计Account1 类,包含: ■ 一个名为 id 的int 类型的私有数据域(默认值为 0),长度为 6 位。 ■ 一个名为 balance的double 类型的私有数据域(默认值为 0)。 ■ 一个名为 annualInterestRate 的double 类型的私有数据域存储当前利率(默认值为 0)。 假设所有的账户都有相同的利率。 ■ 一个名为 dateCreated 的Date 类型的私有数据域存储账户的开户日期。 ■ 一个能创建默认账户的无参构造方法。 ■ 一个能创建带特定 id 和初始余额的构造方法,初始余额不能为负数。 ■ id 、balance和annualInterestRate 的访问器和修改器。 ■ dateCreated 的访问器。 ■ 一个名为 getMonthlyInterestRate 的方法返回月利率。 ■ 一个名为 withDraw 的方法从账户提取特定金额。 ■ 一个名为 deposit 的方法向账户存人特定金额。 ■ double 类型的数据域保留 2 位小数。 ■ 成员方法和数据域应进行基本的合理性检查。 设计测试类 ATMMachine1: ■ 创建一个有 100 个账户的数组,其 id 为0,1,2,...99, 并初始化收支为 1000 美元。 ■ 主菜单如下(可参考教材中文版 P296或英文版 P367): Main menu 1: check balance 2: withdraw 3: deposit 版本2:满分20 分 扩展Account1 类为Account2 类: ■ Account2 类继承 Account1 类。 ■ 为Account2 类新增一个名为 password 的String 类型的私有数据域存储账号密码。 password 只能为字母或数字,长度不能小于 6 且不能大于 10。密码显示时为*******。 ■ 为Account2 类新增一个名为 name的String 类型的私有数据域存储客户名字。 ■ 为Account2 类新增一个名为 transactions 的ArrayList 类型的新数据域,其为客户存 储交易记录。这要求新建一个名为 Transaction 的类,类的定义请参照教材中文版 P327或英 文版P404。每笔交易都是 Transaction 类的一个实例。 ■ 新增一个带初始余额的构造方法,其 id 随产生,但不能与当前系统的 id 重复。 若初始余额的参数为负数,则抛出一个自定义异常并在当前构造方法中进行处理。 ■ 重写方法 withDraw ,要求支取的金额为 100 的整数倍,并且当日支取金额不能超过 5000,支取金额不允许透支。每进行一次操作应向 transactions 数组线性表添加一笔交易。 ■ 重写方法 deposit ,要求每进行一次操作应向 transactions 数组线性表添加一笔交易。 ■ 新增一个方法 changePassword ,只有旧密码正确,新密码符合要求,且两次输入相 同的情况下才可以成功修改密码 设计测试类 ATMMachine2,其主菜单如下(可参考教材中文版 P296或英文版 P367): Main menu 0:create a account 1: check balance 2: withdraw 3: deposit 4:details of the transaction 5: change password 6:exit ■ 若用户选择新建一个账号,则应提示用户输入账号 password 、balance 和 annualInterestRate ,其中 id 随产生。新产生的账户应序列化到名为 accounts.dat 的文件中。 所有账户只能通过这种方式产生。 ■ 所有用户操作结果应同步到 accounts.dat 文件中相应账户中。 ■ 所有用户操作应有友好、简介的提示语。 版本3:满分20 分 请参照银行的 AT M界面,在 Account2 类的基础上开发一个 GUI 界面的AT M系统。 要求界面应模拟小键盘,并且账户信息读、写于文件 accounts.dat 。
### 回答1: 要实现一个Java程序来模拟ATM,并且使用SQL Server作为数据库,可以按照以下步骤进行: 1. 首先,需要创建一个ATM类来作为程序的主类。在这个类中,可以编写主要的逻辑来模拟ATM的操作。 2. 接下来,需要连接到SQL Server数据库。可以使用Java的JDBC API来实现数据库连接。可以使用适当的JDBC驱动程序来连接到SQL Server数据库,并且编写适当的代码来建立连接。 3. 在与数据库连接成功后,可以创建适当的表来存储ATM的相关信息,例如用户信息,账户余额等。可以使用SQL语句来创建表,例如CREATE TABLE语句。 4. 在ATM类中,可以编写适当的方法来实现ATM的功能,例如查询余额,存款,取款等。这些方法可以使用SQL语句来执行对数据库的操作,例如SELECT,INSERT,UPDATE等。 5. 此外,还可以编写适当的验证和错误处理代码,以确保用户输入的正确性和异常情况的处理。可以使用Java的异常处理制来捕获和处理异常情况。 6. 最后,在程序的主方法中,可以实例化ATM类的对象,并调用相应的方法来执行模拟的ATM操作。 通过按照上述步骤,可以使用Java编写一个模拟ATM的程序,并使用SQL Server作为数据库。这样的程序能够模拟实际的ATM操作,并且能够实现用户的存款,取款和查询余额等功能。 ### 回答2: 实现ATM的Java程序需要使用SQL Server数据库进行数据存储和管理。下面是一个简单的实现ATM的步骤: 1. 创建数据库表:首先在SQL Server中创建一个名为"ATM"的数据库,并在该数据库中创建两个表,分别为"Users"和"Transactions"。"Users"表用于存储用户的信息,包括用户ID、姓名、卡号、密码和余额等字段;"Transactions"表用于记录交易记录,包括交易ID、交易类型、交易时间和金额等字段。 2. 连接数据库:在Java程序中使用JDBC技术连接SQL Server数据库,加载数据库驱动程序,并建立与数据库的连接。 3. 用户验证:在ATM程序中,用户需要输入卡号和密码进行验证。程序需要从数据库查询用户表,验证输入的卡号和密码是否匹配。如果匹配成功,进入下一步;如果匹配失败,提示用户重新输入或退出程序。 4. 主菜单:用户成功验证后,程序显示主菜单,用户可以选择不同的操作,包括查询余额、存款、取款和退出等。 5. 查询余额:用户选择查询余额后,程序从数据库中查询用户表并显示用户的余额。 6. 存款:用户选择存款后,程序提示用户输入存款金额,并更新数据库中用户的余额。 7. 取款:用户选择取款后,程序提示用户输入取款金额,并检查用户的余额是否足够进行取款。如果余额足够,程序更新用户余额并记录此次取款的交易记录;如果余额不足,程序提示用户余额不足。 8. 交易记录:每次用户进行存款或取款时,程序将记录该笔交易的相关信息,并保存到数据库的交易记录表中。 9. 退出:用户选择退出后,程序终止运行,断开与数据库的连接。 以上是一个简单的ATM的Java实现步骤,具体的代码实现可以根据需求进行进一步开发和完善。 ### 回答3: 实现ATM的Java程序需要安装并使用SQL Server作为数据库。以下是一种可能的实现方法: 首先,需要创建一个数据库表来存储用户信息和账户余额。可以创建一个名为"users"的表,包含以下字段:用户ID、用户名、密码和账户余额。 在Java程序中,可以使用JDBC连接到SQL Server数据库。首先,需要导入相应的JDBC库,并在程序中设置数据库连接参数,如数据库URL、用户名和密码。 在程序中,可以创建一个"ATM"类,用于处理用户的操作。在该类中,可以实现以下方法: 1. 登录方法:用户输入用户名和密码,程序查询数据库,验证用户信息是否正确。 2. 查询余额方法:用户输入账户ID,程序在数据库中查找对应的账户,并返回账户余额。 3. 存款方法:用户输入账户ID和存款金额,程序在数据库中查找对应的账户,并更新账户余额。 4. 取款方法:用户输入账户ID和取款金额,程序在数据库中查找对应的账户,检查账户余额是否足够,并更新账户余额。 5. 转账方法:用户输入转出账户ID、转入账户ID和转账金额,程序分别在数据库中查找对应的账户,并检查转出账户余额是否足够,并更新转出账户和转入账户的余额。 以上方法可以使用SQL语句执行数据库操作,如查询、更新和插入数据。 在程序的主函数中,可以实现ATM的交互界面,提示用户输入操作类型和相关信息,并调用相应的方法进行处理。 通过以上步骤,就可以实现一个基本的ATMJava程序,并使用SQL Server作为数据库。当然,还可以根据实际需求进行功能扩展和改进。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值