/*
* Copyright (c) 2004 ???. All Rights Reserved.
*
* Version 1.0 , Created on 2004-3-10
*
*/
/**
* @author Devon
*/
/**
* 如何产生和保存密钥
*/
import java.security.*;
import java.security.spec.*;
import javax.crypto.*;
import java.io.*;
public class KeyGeneratorExample {
public static void main(String[] args) {
try{
//产生单钥加密的密钥(myKey)
KeyGenerator keyGenerator = KeyGenerator.getInstance("DESede"); //采用DESede算法
keyGenerator.init(168); //选择DESede算法,密钥长度为112位或168位
Key myKey = keyGenerator.generateKey(); //生成密钥
System.out.println("得到单钥加密密钥");
//产生双钥的密钥对(keyPair)
KeyPairGenerator keyPairGenerator=KeyPairGenerator.getInstance("RSA"); //采用RSA算法
keyPairGenerator.initialize(1024); //指定密钥长度为1024位
KeyPair keyPair = keyPairGenerator.generateKeyPair(); //生成密钥对
System.out.println("生成张三的公钥对");
//保存公钥的字节数组
File f = new File("publicKey.dat"); //保存公钥到文件publicKey.dat
FileOutputStream fout = new FileOutputStream(f);
fout.write(keyPair.getPublic().getEncoded()); //得到公钥的字节数组
fout.close(); //关闭文件输出流
System.out.println("保存公钥到文件: "+f.getAbsolutePath());
//用Java对象序列化保存私钥,通常应对私钥加密后再保存
ObjectOutputStream oout = new ObjectOutputStream(new FileOutputStream("privateKey.dat")); //保存私钥到文件privateKey.dat
oout.writeObject(keyPair.getPrivate()); //序列化私钥
oout.close(); //关闭输出流
System.err.println("保存私钥到: privateKey.dat");
//从文件中得到公钥编码的字节数组
FileInputStream fin = new FileInputStream("publicKey.dat"); //打天publicKey.dat
ByteArrayOutputStream baout = new ByteArrayOutputStream(); //用于写入文件的字节流
int aByte = 0;
while ((aByte = fin.read())!= -1) //从文件读取一个字节
{
baout.write(aByte); //写入一个字节
}
fin.close(); //关闭文件输入流
byte[] keyBytes = baout.toByteArray(); //得到公钥的字节数组
baout.close(); //关闭字节数组输出流
//从字节数组解码公钥
X509EncodedKeySpec x509KeySpec =new X509EncodedKeySpec(keyBytes);
KeyFactory keyFactory = KeyFactory.getInstance("RSA"); //指定算法RSA,得到一个KeyFactory的实例
PublicKey pubKey = keyFactory.generatePublic(x509KeySpec); //解码公钥
System.out.println("从文件中成功得到公钥");
}catch (Exception ex){ex.printStackTrace();
}
}
}
如何产生和保存密钥,选择DESede算法
4星 · 超过85%的资源 需积分: 28 98 浏览量
2009-05-05
21:06:28
上传
评论
收藏 3KB RAR 举报
fenglizh
- 粉丝: 0
- 资源: 8
最新资源
- Screenshot_20240427_031602.jpg
- 网页PDF_2024年04月26日 23-46-14_QQ浏览器网页保存_QQ浏览器转格式(6).docx
- 直接插入排序,冒泡排序,直接选择排序.zip
- 在排序2的基础上,再次对快排进行优化,其次增加快排非递归,归并排序,归并排序非递归版.zip
- 实现了7种排序算法.三种复杂度排序.三种nlogn复杂度排序(堆排序,归并排序,快速排序)一种线性复杂度的排序.zip
- 冒泡排序 直接选择排序 直接插入排序 随机快速排序 归并排序 堆排序.zip
- 课设-内部排序算法比较 包括冒泡排序、直接插入排序、简单选择排序、快速排序、希尔排序、归并排序和堆排序.zip
- Python排序算法.zip
- C语言实现直接插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序、归并排序、计数排序,并带图详解.zip
- 常用工具集参考用于图像等数据处理
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈