非对称加密算法.doc

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
非对称加密算法/数字签名算法——RSA 接下来我们介绍典型的非对称加密算法/数字签名算法——RSA? RSA? ??? 这种算法1978年就出现了,它是第一个既能用于数据加密也能用于数字签名的算法。它易于理解和操作,也很流行。算法的名字以发明者的名字命名:Ron Rivest, AdiShamir 和Leonard Adleman。? ??? 这种加密算法的特点主要是密钥的变化,上文我们看到DES只有一个密钥。相当于只有一把钥匙,如果这把钥匙丢了,数据也就不安全了。RSA同时有两把钥匙,公钥与私钥。同时支持数字签名。数字签名的意义在于,对传输过来的数据进行校验。确保数据在传输工程中不被修改。? 流程分析:? 甲方构建密钥对儿,将公钥公布给乙方,将私钥保留。 甲方使用私钥加密数据,然后用私钥对加密后的数据签名,发送给乙方签名以及加密后的数据;乙方使用公钥、签名来验证待解密数据是否有效,如果有效使用公钥对数据解密。 乙方使用公钥加密数据,向甲方发送经过加密后的数据;甲方获得加密数据,通过私钥解密。 按如上步骤给出序列图,如下:? 通过java代码实现如下:Coder类见? Java加密技术(一)? Java代码?? import?java.security.Key;?? import?java.security.KeyFactory;?? import?java.security.KeyPair;?? import?java.security.KeyPairGenerator;?? import?java.security.PrivateKey;?? import?java.security.PublicKey;?? import?java.security.Signature;?? import?java.security.interfaces.RSAPrivateKey;?? import?java.security.interfaces.RSAPublicKey;?? import?java.security.spec.PKCS8EncodedKeySpec;?? import?java.security.spec.X509EncodedKeySpec;?? ?? import?java.util.HashMap;?? import?java.util.Map;?? ?? import?javax.crypto.Cipher;?? ?? /**? ?*?RSA安全编码组件? ?*?? ?*?@author?梁栋? ?*?@version?1.0? ?*?@since?1.0? ?*/?? public?abstract?class?RSACoder?extends?Coder?{?? ????public?static?final?String?KEY_ALGORITHM?=?"RSA";?? ????public?static?final?String?SIGNATURE_ALGORITHM?=?"MD5withRSA";?? ?? ????private?static?final?String?PUBLIC_KEY?=?"RSAPublicKey";?? ????private?static?final?String?PRIVATE_KEY?=?"RSAPrivateKey";?? ?? ????/**? ?????*?用私钥对信息生成数字签名? ?????*?? ?????*?@param?data? ?????*????????????加密数据? ?????*?@param?privateKey? ?????*????????????私钥? ?????*?? ?????*?@return? ?????*?@throws?Exception? ?????*/?? ????public?static?String?sign(byte[]?data,?String?privateKey)?throws?Exception?{?? ????????//?解密由base64编码的私钥?? ????????byte[]?keyBytes?=?decryptBASE64(privateKey);?? ?? ????????//?构造PKCS8EncodedKeySpec对象?? ????????PKCS8EncodedKeySpec?pkcs8KeySpec?=?new?PKCS8EncodedKeySpec(keyBytes);?? ?? ????????//?KEY_ALGORITHM?指定的加密算法?? ????????KeyFactory?keyFactory?=?KeyFactory.getInsta

文档评论(0)

zhuliyan1314 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档