信息安全课程设计 金融服务系统Word格式文档下载.docx
- 文档编号:21769839
- 上传时间:2023-02-01
- 格式:DOCX
- 页数:47
- 大小:800.37KB
信息安全课程设计 金融服务系统Word格式文档下载.docx
《信息安全课程设计 金融服务系统Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《信息安全课程设计 金融服务系统Word格式文档下载.docx(47页珍藏版)》请在冰豆网上搜索。
5
答辩时思路清晰,重点突出,准确无误
6
设计有独到见解
总分
100
等级
五级制
评语:
指导教师签名:
年月日
第一章课程设计背景
金融业是指经营金融商品的特殊企业,它包括银行业、保险业、信托业、证券业、租赁业和典当业。
在现代社会中,金融业用途广泛:
第一,社会各阶层各行业所有人,都需要资金融通,不论长期的或短期的资金需求,不论国内的或海外的现金需求,不论短期的或远期的资金需求,金融业都可以满足这些需要。
第二,已盈利的企业或个人,他的金钱需要有个存放或运用的去处,金融业正可以满足这个需要。
所以金融服务系统是一个具有优化资金配置的作用的系统,而当下也是一个信息争夺的时代,因此金融信息获取的及时性就相关人员来说就显得尤其重要,影响到公司或个人的投资或融资决策。
于是,金融业经营手段的现代化是急需解决的问题,运用电子计算机和自动化服务能保证信息的共享性和及时性,这也是我们开发本系统的目的。
我们的目的是:
创造一个为客户提供金融信息的平台,金融服务人员可以在该平台发布信息,而所有的注册登录客户都可以及时跟进最新的金融信息,以做出相应的决策。
第二章设计的方案
本系统是运用纯java语言制作的金融服务系统化,客户端—服务器—客户端的消息交互模式。
客户端功能主要包括客户注册、登录、信息发送、在线用户显示。
提供给客户一个友好的界面,方便客户的操作,从服务器上得到数据后再显示给客户,并根据不同的需求,向服务器发送各种请求。
服务端的功能主要包括接受客户注册(采用口令、MD5方式管理保护注册信息)、接受客户登录请求、提示客户离线以及显示端口号、服务器当前状态等。
服务器运行后,开启服务就可以开始监听客户请求,如有信息发送过来,首先发送确认信息,然后建立一个线程,处理接受到得数据,处理结束后,线程就结束,这样可以实时接受每一个客户的请求,不会因为处理一个客户的请求而忽略了其他客户的请求。
我们开发的系统应满足以下技术要求:
1、登录、注册、服务器、客户端等窗体的设计与连接。
2、实现客户账号和密码的对应安全存储;
3、对所有的交流信息进行分组加密;
4、对所有的交流信息进行完整性检验;
5、实现服务器端对客户身份的验证;
6、能够抵挡的攻击人的防重放攻击。
一.注册和登录时——MD5加密算法:
1、简介:
MD5的全称是Message-DigestAlgorithm5(信息-摘要算法)。
它的作用是让大容量信息在用数字签名软件签署私人密匙前被"
压缩"
成一种保密的格式(就是把一个任意长度的字节串变换成一定长的大整数)。
2、应用:
MD5的典型应用是对一段信息(Message)产生信息摘要(Message-Digest),以防止被篡改。
MD5广泛用于加密和解密技术上。
本文描述的系统中用户的密码就是以MD5经加密后存储在服务器。
当用户登录的时候,系统把用户输入的密码计算成MD5值,然后再去和保存在服务器中的MD5值进行比较,进而确定输入的密码是否正确。
通过这样的步骤,系统在并不知道用户密码的明码的情况下就可以确定用户登录系统的合法性。
这不但可以避免用户的密码被具有系统管理员权限的用户知道,而且还在一定程度上增加了密码被破解的难度。
3、算法描述:
对MD5算法简要的叙述可以为:
MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。
4、具体在本系统中的应用:
1 建立MD5Encrypt1类,主要代码为:
byte[]btInput=s.getBytes();
MessageDigestmdInst=MessageDigest.getInstance("
MD5"
);
mdInst.update(btInput);
//处理数据
byte[]md=mdInst.digest();
//完成哈希计算
2 注册时,调用MD5Encrypt1类创建对象:
MD5Encrypt1md5=newMD5Encrypt1();
data.password=md5.MD5(data.password);
由此将注册客户的密码用MD5加密,然后才发送到服务器。
3 第三,登录时,和注册时加密方法一样。
二.沟通过程中,用AES进行分组加密
沟通过程中,我们对各种沟通信息采用对称密码分组加密方法,首先新建一个提供AES加密、解密算法的类,消息从发送端发送时调用AES加密算法,接受端接受到信息再调用AES解密算法进行解密。
AES(TheAdvancedEncryptionStandard)是美国国家标准与技术研究所用于加密电子数据的规范。
它被预期能成为人们公认的加密包括金融、电信和政府数字信息的方法。
在应用方面,尽管DES在安全上是脆弱的,但由于快速DES芯片的大量生产,使得DES仍能暂时继续使用,为提高安全强度,通常使用独立密钥的三级DES。
但是DES迟早要被AES代替。
AES是一个迭代的、对称密钥分组的密码,它可以使用128、192和256位密钥,并且用128位(16字节)分组加密和解密数据。
与公共密钥密码使用密钥对不同,对称密钥密码使用相同的密钥加密和解密数据。
通过分组密码返回的加密数据的位数与输入数据相同。
迭代加密使用一个循环结构,在该循环中重复置换(permutations)和替换(substitutions)输入数据。
1 加密时:
byte[]raw=sKey.getBytes();
SecretKeySpecskeySpec=newSecretKeySpec(raw,"
AES"
//根据给定的字节数组构造一个密钥
Ciphercipher=Cipher.getInstance("
AES/CBC/PKCS5Padding"
//"
算法/模式/补码方式"
//生成一个实现指定转换的Cipher对象
IvParameterSpeciv=newIvParameterSpec("
0102030405060708"
.getBytes());
//初值
//使用CBC模式,需要一个向量iv,可增加加密算法的强度
cipher.init(Cipher.ENCRYPT_MODE,skeySpec,iv);
//加密
byte[]encrypted=cipher.doFinal(sSrc.getBytes());
2 解密时:
byte[]raw=sKey.getBytes("
ASCII"
cipher.init(Cipher.DECRYPT_MODE,skeySpec,iv);
//解密
byte[]encrypted1=hex2byte(sSrc);
3 StringaesKey=randkey.randomString(16);
//调用方法随机产生AES密钥
三.(MAC)进行完整性检查以及抵抗窃听者的重放攻击
MAC算法(MessageAuthenticationCodes),即消息认证码(带密钥的Hash函数):
消息的散列值由只有通信双方知道的秘密密钥K来控制。
此时Hash值称作MAC。
消息认证码是基于密钥和消息摘要所获得的一个值,可用于数据源发认证和完整性校验。
是通信实体双方使用的一种验证机制,保证消息数据完整性的一种工具。
在发送数据之前,发送方首先使用通信双方协商好的散列函数计算其摘要值。
在双方共享的会话密钥作用下,由摘要值获得消息验证码。
之后,它和数据一起被发送。
接收方收到报文后,首先利用会话密钥还原摘要值,同时利用散列函数在本地计算所收到数据的摘要值,并将这两个数据进行比对。
若两者相等,则报文通过认证。
算法流程如下:
1 Stringmackey=mac.getMacKey();
//调用方法随机产生MAC密钥
Stringmacmiwen=mac.toHex(mac.encryptHMAC(data,mackey));
//MAC加密
2 取得HMAC密钥:
KeyGeneratorkeyGenerator=KeyGenerator.getInstance("
HmacMD5"
SecretKeysecretKey=keyGenerator.generateKey();
3 执行加密:
byte[]bkey=newBASE64Decoder().decodeBuffer(key);
SecretKeysecretKey=newSecretKeySpec(bkey,"
Macmac=Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
另外:
StringR=randkey.randomString(10);
//生成10位随机数R,用于防重放认证。
StringopenKey="
145gh89sc83fgjpw"
;
//用于总体传送时外套的公共密钥
第三章方案分析
一.MD5安全性:
VanOorschot和Wiener曾经考虑过一个在散列中暴力搜寻冲突的函数(Brute-ForceHashFunction),而且他们猜测一个被设计专门用来搜索MD5冲突的机器(这台机器在1994年的制造成本大约是一百万美元)可以平均每24天就找到一个冲突。
但单从1991年到2001年这10年间,竟没有出现替代MD5算法的MD6或被叫做其他什么名字的新算法这一点,我们就可以看出这个瑕疵并没有太多的影响MD5的安全性。
上面所有这些都不足以成为MD5的在实际应用中的问题。
并且,由于MD5算法的使用不需要支付任何版权费用的,所以在一般的情况下(非绝密应用领域。
但即便是应用在绝密领域内,MD5也不失为一种非常优秀的中间技术),MD5怎么都应该算得上是非常安全的了。
这也是我们选用MD5算法的根本原因。
二.AES安全性:
AES算法的密钥长度最小是128比特,即使每秒钟能够完成256个密钥的搜索,至少需要的时间大约是149万亿年。
因此,Rijndael算法对强力攻击是免疫的。
这就是我们选择AES的最主要的原因,而且每次发送消息的密钥都是随机产生的,起到了更好的保护作用。
三.MAC安全性:
MAC类似于加密,区别是MAC函数是单向的,因为它不需要解密,这个性质使得鉴别函数比加密函数更不容易被破译,安全强度提高了,起到很好的认证效果。
且用产生的随机数R检验,保证信息传输的可靠性。
第四章设计成果
我们开发的系统应满足以下功能需求:
1、金融服务人员可以在一个安全的平台发布金融信息以及投资建议;
2、这些信息只有该金融服务集团的客户可以读取;
3、这些信息可以被所有的该金融服务集团的客户获取;
4、客户可以再该系统与服务人员或者是客户之间可以进行简单的沟通和交流;
5、金融服务人员可以识别登录人的身份;
金融服务人员可以查看各登录人的登录和退出时间。
一.以下是该系统的主要功能流程图:
图一客户注册功能流程图
备注:
客户注册时,需要填写注册信息,包含“客户名”、“密码”和“邀请码”。
其中邀请码由金融机构工作人员填写,若邀请码不等于系统内置的邀请码,则注册不能成功。
这样做,保证了,不能随便任何人都可以注册成功,只有经过了工作人员核查信息之后,方能帮助其完成注册信息。
图二客户登录功能流程图
客户登录时,需要输入“客户名”和“密码”,若信息与注册时保存在服务器端的信息相匹配,则,客户可进入到服务平台,否则,登录失败。
图三消息加密、解密、认证流程图
登录各方发送消息时,要发送“验证码”、“明文”、“随机数”,其中明文要通过AES加密和解密,验证码用来验证信息的完整性,若解密之后的明文的验证码和接收到的验证码不同则舍弃该信息,若相同,则发布信息到服务平台。
随机数的产生是用来防止重放攻击。
二.以下是该系统主要界面:
1、首先运行服务器,后启动服务器。
图一金融服务系统——服务器管理界面
如果未开启服务器,系统将会出现如下图的提示:
图二登入失败页面
2.客户登录
图三代理和客户登入页面
在这个页面我们用户名和密码都设置了非空的约束,如果输入错误的密码的用户名,系统将会提示“用户名或密码不能为空”。
你也可以点击“注册”进入注册页面。
3.客户注册
图四代理或客户注册页面
在这个页面我们设置了邀请码的功能,系统指定一个只有代理拥有的特定邀请码,当客户在注册的时候需要代理代其输入邀请码,这在一定程度上限制了非任何人均可进入金融消息系统。
在注册和登入成功后,服务器将会提示如下消息
图五注册和登入成功后服务器页面
4.金融消息发布
此时页面将跳转到金融消息发布页面,如图所示:
图六金融融消息发布页面
接下来,你就可以在这里接受和发布消息了:
图七整体效果图
当代理发送消息时系统根据MD5加密算法和AES加密、解密算法生成一系列密文和密钥。
第五章总结
通过这次金融信息服务系统的开发,我们实现了金融服务人员向其客户发布信息的功能,并且保证了这些信息的保密性和完整性。
在系统的设计上我们主要考虑两大方面问题:
(1)制作完整的金融信息系统
(2)对金融信息服务系统进行安全性设置
本模块主要考虑的是服务器对用户密码的保护功能、发送端与接收端信息交互过程的加密功能、信息传输过程中的完整性判断功能、接收方信息传输过程中的防重放功能。
但是我们这个系统也存在着一定的缺陷,比如客户如果想和某一客户或者服务人员沟通时,会使所有登录人员都看到其沟通信息,我认为我们可以进一步完善底层通讯协议,使能够更好的处理数据的发送和接受,需做到以下几点:
(1)多线程下的对临界数据访问的问题。
(2)对本地用户名和密码的保存问题,在本程序中,没有对本地用户名和密码设置缓存。
也就是说用户登录一次后,系统不会自动的保存下用户的用户名和密码,使得用户在第二次进入系统时还要重新输入用户名。
(3)在客户端系统,功能的设置有待进一步丰富,功能的实现还有待完善和改进。
参考文献
【1】辛运帏饶一梅马素霞java程序设计清华大学出版社
【2】张焕国王张宜密码学引论武汉大学出版社
【3】
【4】
【5】
【6】
附录(代码)
Client.java
//客户端程序
importjavax.swing.*;
importjava.awt.*;
importjava.awt.event.*;
import.*;
importjava.io.*;
importjava.util.*;
publicclassClientextendsJFrameimplementsActionListener{
JPanelpnlLogin;
JButtonbtnLogin,btnRegister,btnexit;
JLabellblServer,lblPort,lblName,lblPassword,lblLogo;
JTextFieldtfName,tfServer,tfPort;
JPasswordFieldpwd;
StringstrServerIp;
intport;
//用于将窗口定位
//DimensionscnSize=Toolkit.getDefaultToolkit().getScreenSize();
privateDimensionscrnsize;
privateToolkittoolkit=Toolkit.getDefaultToolkit();
publicClient(){//构造方法
super("
登录金融服务系统"
pnlLogin=newJPanel();
this.getContentPane().add(pnlLogin);
lblServer=newJLabel("
服务器:
"
lblPort=newJLabel("
端口:
lblPort.setVisible(false);
lblName=newJLabel("
用户名:
lblPassword=newJLabel("
密码:
tfServer=newJTextField(20);
tfServer.setText("
127.0.0.1"
tfPort=newJTextField(4);
tfPort.setText("
8888"
tfPort.setVisible(false);
tfName=newJTextField(20);
pwd=newJPasswordField(20);
btnLogin=newJButton("
登录"
btnRegister=newJButton("
注册"
btnexit=newJButton("
取消"
pnlLogin.setLayout(null);
//组件用手动布局
lblServer.setBounds(80,140,50,30);
tfServer.setBounds(80,170,120,25);
//lblPort.setBounds(175,15,30,30);
//tfPort.setBounds(210,15,40,25);
lblName.setBounds(80,200,100,30);
tfName.setBounds(80,230,120,25);
lblPassword.setBounds(80,260,100,30);
pwd.setBounds(80,290,120,25);
btnLogin.setBounds(30,320,80,25);
btnRegister.setBounds(110,320,80,25);
btnexit.setBounds(190,320,80,25);
pnlLogin.add(lblServer);
pnlLogin.add(tfServer);
pnlLogin.add(lblPort);
pnlLogin.add(tfPort);
pnlLogin.add(lblName);
pnlLogin.add(tfName);
pnlLogin.add(lblPassword);
pnlLogin.add(pwd);
pnlLogin.add(btnLogin);
pnlLogin.add(btnexit);
pnlLogin.add(btnRegister);
lblName.setForeground(Color.BLACK);
lblPassword.setForeground(Color.BLACK);
//设置背景图片
Iconlogo1=newImageIcon("
images\\loginlogo.jpg"
lblLogo=newJLabel(logo1);
lblLogo.setBounds(0,0,300,140);
pnlLogin.add(lblLogo);
//设置登录窗口
setResizable(false);
setSize(300,400);
setVisible(true);
//setLocation((scnSize.width-getWidth())/2,(scnSize.height-getHeight())/2);
scrnsize=toolkit.getScreenSize();
setLocation(scrnsize.width/2-this.getWidth()/2,scrnsize.height
/2-this.getHeight()/2);
Imageimg=toolkit.getImage("
images\\appico.jpg"
setIconImage(img);
//为按钮注册监听
btnexit.addActionListener(this);
btnLogin.addActionListener(this);
btnRegister.addActionListener(this);
addWindowListener(newWindowAdapter(){
publicvoidwindowClosing(WindowEvente){
System.exit(0);
}
});
//按钮监听响应
publicvoidactionPerformed(ActionEventae){
Objectsource=ae.getSource();
strServerIp=tfServer.getText();
try{
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 信息安全课程设计 金融服务系统 信息 安全 课程设计 金融 服务 系统