Java安全(四)-输入流的解密
2017-01-30 17:29
453 查看
本实例演示针对输入流的解密,将JAVA安全笔记(三)-输入流加密 的加密文件进行解密,并把解密后的结果输入指定的另外一个文件
2.初始化密码器
3.获取解密的内容
4.创建CipherInputStream对象
5.读取输入流
6.存入相应文件中
源代码
运行结果
源程序解读
(1) FileInputStream f=new FileInputStream("C:\\Users\\Administrator\\Desktop\\key1.dat");
该语句从文件所用的中读取加密时所用的密钥,这样保证了本实例的密钥和加密时的密钥相同,以便于对比解密后的结果
key1.dat的生成由 Java安全笔记(二)创建对称密钥
加密程序 JAVA安全笔记(三)-输入流加密
(2) FileInputStream in=new FileInputStream("C:\\Users\\Administrator\\Desktop\\E_InStream.dat");
该语句的作用是获取要解密的文件,本程序是以 加密程序生成的文件为例,文件名为E_InStream.dat
(3) CipherInputStream cin=new CipherInputStream(in, cp);
该语句的作用是创建CiperInputStream对象,根据前面所创建好的密码器和输入流为参数构造CipherInputStream对象
(4) 同java.io包中的基本的输入流一样使用read()方法从CipherInputStream流中读取数据。
则在读取过程中会自动根据密码器中的设置进行解密。
输入流的解密技术要点如下
1.密钥生成2.初始化密码器
3.获取解密的内容
4.创建CipherInputStream对象
5.读取输入流
6.存入相应文件中
源代码
package ende; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.ObjectInputStream; import java.security.Key; import javax.crypto.Cipher; import javax.crypto.CipherInputStream; public class D_InStream { public static void main(String[] args) throws Exception { //生成密钥 FileInputStream f=new FileInputStream("C:\\Users\\Administrator\\Desktop\\key1.dat"); ObjectInputStream ob=new ObjectInputStream(f); Key k=(Key)ob.readObject(); Cipher cp=Cipher.getInstance("DESede"); //创建密码器 cp.init(Cipher.DECRYPT_MODE, k);//初始化密码器,解密模式DECRYPT_MODE FileInputStream in=new FileInputStream("C:\\Users\\Administrator\\Desktop\\E_InStream.dat"); CipherInputStream cin=new CipherInputStream(in, cp);//创建CiperInputStream对象 int b=0; int i=1; FileOutputStream out =new FileOutputStream("C:\\Users\\Administrator\\Desktop\\D_InStream.txt");//将密文保存到指定的文件中 System.out.println("对文件输入流解密的原文如下"); while((b=cin.read())!=-1){ //读输入流 System.out.print((byte) b+" "); out.write((byte)b); // 书中代码中漏掉的,要往文件中写 i++; if(i%30 == 0) System.out.println(); } } }
运行结果
源程序解读
(1) FileInputStream f=new FileInputStream("C:\\Users\\Administrator\\Desktop\\key1.dat");
该语句从文件所用的中读取加密时所用的密钥,这样保证了本实例的密钥和加密时的密钥相同,以便于对比解密后的结果
key1.dat的生成由 Java安全笔记(二)创建对称密钥
加密程序 JAVA安全笔记(三)-输入流加密
(2) FileInputStream in=new FileInputStream("C:\\Users\\Administrator\\Desktop\\E_InStream.dat");
该语句的作用是获取要解密的文件,本程序是以 加密程序生成的文件为例,文件名为E_InStream.dat
(3) CipherInputStream cin=new CipherInputStream(in, cp);
该语句的作用是创建CiperInputStream对象,根据前面所创建好的密码器和输入流为参数构造CipherInputStream对象
(4) 同java.io包中的基本的输入流一样使用read()方法从CipherInputStream流中读取数据。
则在读取过程中会自动根据密码器中的设置进行解密。
相关文章推荐
- JAVA安全篇网站登陆加密解密
- Java安全编程:RSA加密解密
- JAVA:安全证书-公钥加密,私钥解密示例程序
- Android 安全——Java环境动态加载Jar之Jar包的加密和解密
- java安全与加解密
- java安全架构____java DSA加密解密
- Java安全学习笔记(十一)-RSA算法加密和解密
- Java安全编程:DES加密解密
- 公钥和私钥的含义,以及java客户端和服务器之间进行安全加解密的简单实现
- 网络传输安全--前端js加密后端java解密
- JAVA安全笔记(三)-输入流加密
- Java安全学习笔记(十)-输出流的加密和解密
- java安全 加密解密!
- java安全AES加密解密
- java加密与解密的艺术(一)——何谓数据安全?
- 全面保护你的Java程序安全(上)
- JAAS:灵活的Java安全机制(3)
- Java安全通信、数字证书及数字证书应用实践
- 安全设置运行 Java 服务的 Linux [转载]