- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)