Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2254976
  • 博文数量: 292
  • 博客积分: 10016
  • 博客等级: 中将
  • 技术积分: 3381
  • 用 户 组: 普通用户
  • 注册时间: 2005-11-06 11:26
文章分类

全部博文(292)

文章存档

2011年(1)

2010年(4)

2009年(3)

2008年(6)

2007年(47)

2006年(63)

2005年(168)

分类: 项目管理

2007-06-03 00:14:31

主要用于数字签名:

1.存储密钥对

首先使用KeyPairGeneration产生密钥对:

        KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA");
        keyGen.initialize(1024);
        KeyPair keyPair = keyGen.genKeyPair();
        privateKey = keyPair.getPrivate();
        publicKey = keyPair.getPublic();

 

将密钥存储为文件的方法:

        FileOutputStream fs = new FileOutputStream(fileName);
        fs.write(privateKey.getEncoded());
        fs.close();

2.加载密钥对

假设公钥文件为public.dat、private.dat

首先读取公钥文件:

        //read public key
        FileInputStream fsPublicKey = new FileInputStream(publicKeyFile);
        BufferedInputStream bfsPublicKey = new BufferedInputStream(fsPublicKey);
        byte[] bytePublicKey = new byte[bfsPublicKey.available()];
        bfsPublicKey.read(bytePublicKey);
        bfsPublicKey.close();

使用KeyFactory产生公钥

        //build public key
        X509EncodedKeySpec  pubKeySpec = new X509EncodedKeySpec(
                byteEncodedPublicKey);
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");
        PublicKey pubKey = keyFactory.generatePublic(pubKeySpec);

 

主意,私钥的的处理和公钥相同,唯一不同的是私钥的KeySpec不同。私钥应使用PKCS8EncodedKeySpec。

阅读(2988) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~