【JAVA核心技术】加密之公共密钥

本文介绍了公钥密码技术如何解决对称密码在密钥分发上的问题。详细阐述了RSA算法的工作原理,并提供了Java实现RSA加密解密的步骤,包括生成密钥对、加密文件和解密文件的过程。
摘要由CSDN通过智能技术生成

AES密码是一种对称密码,加密和解密都要使用相同的密钥。对称密码的致命缺点在与密码的分发。如果A给B发送一个加密方法,那么B需要使用与A相同的密钥。如果A修改了密钥那么他必须在给B发送信息的同时,还需要通过安全信道发送新的密钥,但是也许他并不拥有到达B的安全信道,这就是为什么他必须首先对他发送给B的信息进行加密的原因。


公共密钥密码技术解决了这个问题。在公共密钥密码中,B拥有一个密钥对,包括一个公共密钥和一个相匹配的私有密钥。B可以在任何地方公布公共密钥,但是他必须严格保守他的私有密钥。A只需要使用公共密钥对他发送给B的信息进行加密即可。


那么将公共密码和对称密码结合起来这个问题可以得到解决:

1)A生成一个随机对称加密密钥,他用该密钥对明文进行加密。

2)A用B的公共密钥给对称密钥进行加密。

3)A将加密后的对称密钥和加密后的明文同时发送给B

4)B用他的私有密钥给对称密钥解密。

5)B用解密后的对称密钥给信息解密。

最普通的公共密钥算法是RSA.。清单代码如下:

import java.io.*;
import java.security.*;
import javax.crypto.*;

/**
 * This program tests the RSA cipher. Usage:<br>
 * java RSATest -genkey public private<br>
 * java RSATest -encrypt plaintext encrypted public<br>
 * java RSATest -decrypt encrypted decrypted private<br>
 * 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值