资源简介
实现java代码生成cer证书文件,然后可以通过代码获取 不通过keytool工具。生成密钥对。使用公钥加密。
代码片段和文件信息
package com.ufida.ehr.sso.cert;
import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.math.BigInteger;
import java.nio.charset.Charset;
import java.security.InvalidKeyException;
import java.security.KeyPair;
import java.security.NoSuchProviderException;
import java.security.SecureRandom;
import java.security.Security;
import java.security.SignatureException;
import java.security.cert.CertificateFactory;
import java.security.cert.X509Certificate;
import java.util.Date;
import javax.security.auth.x500.X500Principal;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.x509.X509V1CertificateGenerator;
/**
* 实现对证书的操作,生成证书,获取证书
* @author Administrator
*
*/
public class CertHandlers {
/**
*
* @param pair 密钥对
* @param bdate 有效期
* @param edate 有效期
* @param info 证书信息
* @return
* @throws InvalidKeyException
* @throws NoSuchProviderException
* @throws SignatureException
*/
@SuppressWarnings(“deprecation“)
public X509Certificate generateV1Certificate(KeyPair pairDate bdateDate edateX500Principal info)
throws InvalidKeyException NoSuchProviderException SignatureException
{
// generate the certificate
Security.addProvider(new BouncyCastleProvider());
X509V1CertificateGenerator certGen = new X509V1CertificateGenerator();
certGen.setSerialNumber(BigInteger.valueOf(System.currentTimeMillis()));
certGen.setIssuerDN(info);
certGen.setNotBefore(bdate);
certGen.setNotAfter(edate);
certGen.setSubjectDN(new X500Principal(“CN=Test Certificate“));
certGen.setPublicKey(pair.getPublic());
// i get error here
certGen.setSignatureAlgorithm(“SHA256WithRSAEncryption“);
return certGen.generateX509Certificate(pair.getPrivate() “BC“);
}
/**
* * 生成证书文件
* @param address 文件保存的路径
* @param bdate 有效期
* @param edate 有效期
* @param info 证书信息
* @param algorithm 算法名称
* @param keysize 密钥长度
* @param random 随机源
* @throws Exception
*/
public void ProCert(String addressDate bdateDate edateX500Principal infoString algorithmint keysize SecureRandom random)throws Exception{
// create the keys
KeyGen pc = new KeyGen();
KeyPair kp = pc.getKeyPair(algorithm keysize random);
// generate the certificate
X509Certificate cert = generateV1Certificate(kpbdateedateinfo);
// show some basic validation
cert.checkValidity(new Date());
cert.verify(cert.getPublicKey());
FileOutputStream o = new FileOutputStream(address);
Writer wr = new OutputStreamWriter(o Charset.forName(“UTF-8“));
wr.write(“-----BEGIN CERTIFICATE-----\n“);
wr.write(new sun.misc.base64Encode
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 3948 2011-10-27 09:16 cert\CertHandlers.java
文件 1402 2011-10-27 09:18 cert\KeyGen.java
文件 816 2011-10-27 09:26 cert\test.java
目录 0 2011-10-27 09:20 cert
----------- --------- ---------- ----- ----
6166 4
- 上一篇:J2EE的13种核心模式
- 下一篇:android各种传感器
相关资源
- J2EE的13种核心模式
- Java记事本 基本功能 查找 撤销 替换
- javacc编译原理实习
- jpcap资源
- RSAJava实现代码
- Student_Manage.zip
- Java通过WTC调Tuxedo服务(String)
- 东北大学计算机考研Java知识点笔记
- java使用HttpClient通过url文件到本地
- java调用Cloudera Manager Api
- JAVA毕业设计外文翻译 中英对照版
- java下进行抓包使用的jpcap.dll和jpcap.
- java swing-jtree的用法
- JAVA实现a*算法八数码问题
- Java简单计算器Swing版
- java-根据网站链接url生成二维码qrcod
- 基于Java的坦克大战游戏含代码和报告
- voiipui开发设计详细
- java 简易计算器的实现
- uc浏览器java手机版UC8.6 java通用版本
- 打砖块JAVA游戏代码
- beiyou Java作业 -3
- java图片浏览器
- 在线拍照Java代码实现
- JAVA分数计算器
- 简单的RSA算法的实现
- JAVA实现BGN同态加密算法
- java httpclient 模拟登录
- 磁盘调度算法java实现
- java实现推荐系统源码
评论
共有 条评论