ImageVerifierCode 换一换
格式:DOCX , 页数:9 ,大小:113.62KB ,
资源ID:8790015      下载积分:10 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/8790015.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请


权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4009-655-100;投诉/维权电话:18658249818。

注意事项

本文(JAVA对安全性的支持.docx)为本站上传会员【xrp****65】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

JAVA对安全性的支持.docx

1、 java对安全性的支持 序言: 在完成网络安全的算法库是,我选择了java语言来开发。由于 java 没有指针,使我对数据流的控制感到很是头痛, 于是对java 编程很有意见, 然而在我使用大数类(BigInteger)时,无意中发现java对RSA封装的很好,再仔细看相关的资料,觉得里面有不少东西,于是决定以此为本学期的论文题目,希望通过这次学习能够从实用的角度更加深入的了解网络安全的一些概念。本着学以至用的观点,我自己设计了一个系统,虽然比较幼稚,但我尽量用上们所学的算法和应用流程,相信着对我今后对网络安全的理解会很有帮助的. java 中安全性方面的概述

2、 系统结构 以 JDK 1.2 为例.。首先无论代码来自本地或是远端,都要对应一个安全策略(security policy)----- 它定义了不同签名者、不同来源的一套权限控制策略(permissions), 在权限控制中说明了对资源( 如文件、目录、端口。。)的访问的权限。 运行系统将代码组织到单独的域 (domains) 中---- 每个域封装了一组具有相同控制权限的类的实例。域相当于 SandBox (沙箱),Applet 可以在管理员的授权下运行于一个受到限制的环境中,而应用程序就不用受到这些限制,当然他也受到安全策略的控制。 JDK 1.2 Security Model:

3、 密码使用的体系结构 JDK1.2 不但保留了以前的 签名算法、消息摘要算法、密钥生成算法, 还增加了 密钥管理、算法参数管理、算法 参数生成、支持不同密钥转化的代理,认证中心 、随机数生成算法。JDK1.2 中还增加了一些加密算法的扩展包(Java Cryptography Extension 即 JCE),提供了全面的平台无关的API 函数 ,实现了数字签名、md5、SHA-1、基于X.509 的认证代理。。。; 下图显示了 JCE 的模型 : 关于Appelt 权限控制的简介 : Java平台通过安全管理器(security manager)来防止系统遭到攻击

4、现在的JDK 系统是通过启动安全管理器来进行资源访问控制的。现在的浏览器中都装有安全管理器,Applet 的一举一动都受到管理器的控制下,与JDK 1.2 平台兼容的系统需要通过 policy 文件来授权。 在policy 文件中定义了来自某地(URL)的某人签名的代码的访问权限控制 ,在JDK 1.2 中,可以通过工具 policytool 来生成、编辑 policy 文件.。 关于应用程序权限控制的简介 : 如果没有安全管理器控制的话,应用程序是完全自由的(此时安全管理器是不会自动启动的)。通过用命令行 -Djava.security.manager 来运行程序,就和下载的A

5、pplet 一样受到了安全管理器的控制。Windows:的缺省的policy 控制文件是 java.home\lib\security\java.policy 。 几个重要的概念 为了保证代码和文挡的安全性,需要签名、证书、和密钥管理方面有支持; 数字签名 数字签名的思路大致是这样的: ² 用Keytool 或 API 生成的私钥给文档或代码签名 ² 将文档(代码) 和签名,带有公钥的证书发给接收者 ² 接收者通过公钥来确认接收到的文件的完整性 ² 接收者通过证书或确定情况来确认发送者身份 证书 证书包括了以下几个部分:: ² 公钥 ² 实体标识 ; 可

6、能包括实体名、实体公司名、所在城市、国家等等 ² 数字签名 : 分发这份证书的实体对证书签名 ² 分发这份证书实体的标识 要确认某份证书是可信的,只需确认签发证书的实体是可信的[ 其公钥是可信的] 。实际中可能第一次的出的公钥存在于另一个人的签名文档中,这样就需要建立一个信任链,看最终的公钥是否是可信任的。成功地建立了信任链以后,就可以计算出该证书的指纹(fingerprint(s) )-- 一般是证书的一个 Hash 码 ;接受者可以打电话给证书发放者比较两处的指纹是否相同,以确认自己受到的证书是他发的,并且中途没有被修改过。接下来需要确认发送者的身份,如果发送者是自己信任的( 已确认

7、并保存了其共钥) ,确认完成。否则就需要第三方( CA )来得到证书。首先发一个自签的证书给 CA ,CA 通过检查证书信息(比如身份证编码什么的)来确证,然后生成一个自签名的证明发送者身份的证书。任何信任这个 CA 的人都相信这份证书上公钥和实体的对应。 系统将所有信任的证书存储起来( Keystore ), 以后收到了带签名的代码或文档,就可以通过jarsigner ,系统 API 来确认;如果在安全策略文件中说明了信任某实体签名的代码,在下载后系统会自动确认。 如果是将签名后的代码或文档发送给其他人,需要将自己的证书捎带上去以便对方确认。keytool – export 或 A

8、PI 函数可以从 KeyStore 中将证书附加在被签名的文档中。如果是用 jarsigner ,他自动将证书带上。 密钥管理 通过一个带密码的数据库来存储自己的私钥及信任的公钥( 称为 Keystore );它包括了两类入口 : 信任证书和证书密钥对(自己的私钥和证书) [ 与 PGP 类似 ],他们都可以通过别名来标识。一个 KeyStore 的所有者可以通过不同的别名来标记不同的 证书- 私钥对而用于不同的场合。 通过 java 工具来实现基本流程 工具介绍: 密钥和证书管理工具( Keytools ) 它主要是负责 公 – 私钥对 、向C A 发证书申请、接受

9、 CA 的回复、记录信任的公钥—实体 对应表, 维护密钥库 ( keystore ) , 命令基本形式是: keytool command options 主要有如下几种命令: ² - certreq – 产生一个证书签名请求(Generate a Certificate Signing Request ,CSR)给 CA , 由它来认证自己的证书。 ² -delete – 删除对应的密钥库的记录 ² - export 将公钥证书输出到某个文件 ² - genkey. 在密钥库中存入私钥- 公钥对, 后者保存在一个自签的证书中。 ² --import 将一个信任的证书

10、导入,或者是接到了CA 的回复,将该证书取代原来密钥库中自签的证书。 ² keypasswd – 为某私钥分配密码 ² -list - 列出密钥库中所有入口 ² -storepasswd 给密钥库分配密码 . Java文档处理工具(jar) 如果要对代码签名,需要先用 jar 将其打包,然后用jarsigner 来签名, 命令的基本格式是jar cf jar-file input-file(s) Java 文档签名及验证工具 (jarsigner) jarsigner 工具通过密钥库中的数据来对 jar 文件进行签名和认证; 策略编辑器 (pol

11、icytool ) 编辑系统的策略文件 使用代码签名 1.签名方大致流程如下所示 : 各个步骤通过前面的工具使用介绍,具体实现细节就不再描述了, 现在列出自己尝试时使用的几个命令: ² [ 生成私钥]keytool -genkey -alias signFiles -keypass 123456 -keystore store -storepass 123456 ² [ 打包 ]jar cvf algrim.jar *.class ² [ 签名 ]jarsigner -keystore store -signedjar sAlgrim.jar Algrim.jar si

12、gnFiles ² [生成证书] keytool -export -keystore store -alias signFiles -file cer.cer 2.接收方大致流程如下所示 : 直接运行代码是不允许的,只有先将证书引入本地的 keystore , 作为信任的证书插入;通过使用 Policy Tool 来配置相应的策略文件,通过两种方式来运行他: 1. 用 java -Djava.security.manager -Djava.security.policy= raypolicy -cp sCount.jar AppName 的形式 2. 通过配置浏览

13、器使用的j ava.home\lib\security\java.security 文件,就可以带安全检查地运行该程序。 文件交换 在发送文件时,可以通过数字签名来保证文件的一致性和发送者的身份。步骤如下 : 发送者[基本流程同代码签名是一样的] 接收者 与代码签名的不同之处在于是通过 jarsigner 来验证的。 使用 JDK 1.2 的API 来构造自己的例程 基础 API 产生公钥和密钥对 ² [ 得到密钥产生器]KeyPairGenerator keyGen = KeyPairGenerator.getInstance("DSA", "SUN

14、"); ² [ 初始化密钥产生器] SecureRandom random = SecureRandom.getInstance("SHA1PRNG", "SUN"); keyGen.initialize(1024, random); ² [产生公钥和密钥] KeyPair pair = keyGen.generateKeyPair();PrivateKey priv = pair.getPrivate(); PublicKey pub = pair.getPublic(); 对数据签名 ² [ 得到一个签名对象] Signature dsa = Signature.getIn

15、stance("SHA1withDSA", "SUN"); ² [初始化签名对象] dsa.initSign(priv); ² [对数据签名 ] dsa.update(buffer, 0, len); ² [得到签名的数据] byte[] realSig = dsa.sign(); 存储签名和公钥 ² 签名结果直接按字节流存储 ² 公钥通过pub.getEncoded(); 先转换为字节流来处理 从文件中取得公钥 ² 先从文件中读到字节流中 à encKey ² [构造一个密钥说明类] X509EncodedKeySpec pubKeySpec = new X5

16、09EncodedKeySpec(encKey); ² [构造一个密钥管理器] KeyFactory keyFactory = KeyFactory.getInstance("DSA", "SUN"); ² [取得公钥] PublicKey pubKey = keyFactory.generatePublic(pubKeySpec); 验证签名 ² [ 同生成签名一样先取得签名对象] ² [用公钥初始化签名对象] sig.initVerify(pubKey); ² [取得被签名的数据] sig.update(buffer, 0, len); ² [验证] boolean v

17、erifies = sig.verify(sigToVerify); 关于访问控制支持 Policy 在SUN 的java 包中的对安全的支持的接口( Interface ) java.security.Certificate java.security.Key java.security.Principal 可以提供 identify 的任何实体 java.security.PrivateKey java.security.PublicKey 在 java.security.acl 还提供了支持访问控制的接口 java.security.acl.Ac

18、l 多个 acl 的入口的集合 java.security.acl.AclEntry acl 的入口 java.security.acl.Group 一组 Principal java.security.acl.Owner Acl 的管理者 java.security.acl.Permission 控制信息 运用自己的算法类和 Java JDK 支持完成网络银行原型 前段时间我用 java 实现了课程中几个重要的算法 : 加密的 des 算法, 通过大数类的支持实现了 RSA 算法 , MD5 函数及带密码的签名算法, 但由于我还没有找到比较好的 Java

19、 处理字节流的方法,所以接口不是很清晰,特别是用了大数类,使得网上的数据传输比较麻烦, 而目前我又没办法找到 java 对 RSA 和 加密算法的支持代码 [ 可以从网上的 JCE 部分找到 ], 这部分就使用了我编的算法, 加上时间关系我不能实现用x.509 标准来表示公钥等,所以系统的设计不是很流畅,权当是课后的一次练习。 系统设计 大致的示意图: < 由于钱目前不能通过 Internet 传输,这里认为客户端是一个管存取钱的代理 > 客户端界面 客户端界面 Server代理 Client代理 Client代理

20、 TCP/IP Web Server代理 事务处理中心 Client代理 向客户端提供的接口有: 0. Login ( [in] Uid , [in] password ) 1. UpdateBalance([ in ] AccountNumber , [ int ] AccountHolder ,[ in ] AccountBalance ,[out] errInfo) 存/取操作。BankServer 确认用户帐号和用户后更改用户的存款数目。 2.

21、CloseAccount([ in ] AccountNumber , [ int ] AccountHolder ,[ in ] AccountBalance ) 消户。BankServer 确认用户帐号和用户后将户头取消。 安全性方面的测略 ² 由于要求在流览器中实现,在本地存取证书的方式是不可行的,对于用户身份认证还是采取了传统的 uid + PWD 的形式,但为了保密,在上传时先用银行的公钥用 RSA 算法加密 [ 该信息直接放在 Applet 的参数中 ] ² 由于没有证书管理措施,不妨认为用户是先执有效证件到银行开户以后取得帐号,设置了密码。用户在每次连接前先生成自己的一份证书,在Log in 时将公钥用x.509的格式[ java 类支持]上传给银行, 由于我自己的算法没法和java 类兼容,所以会话密钥用我自己的方式再上传给银行 ² 银行每次确认连接后保留收到的用户的公钥证书。 ² 用户形成命令后,先签名然后用约定的会话密钥对数据进行加密。 ² 银行收到数据后,先用会话密钥解密,然后检查数据签名,对返回结果用会话密钥加密。

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服