电子签章
数字证书常见标准
- 符合PKI ITU-T X509标准,传统标准(.DER .PEM .CER .CRT)
- 符合PKCS#7 加密消息语法标准(.P7B .P7C .SPC .P7R)
- 符合PKCS#10 证书请求标准(.p10)
- 符合PKCS#12 个人信息交换标准(.pfx *.p12)
X509是数字证书的基本规范,而P7和P12则是两个实现规范,P7用于数字信封,P12则是带有私钥的证书实现规范。
生成p12证书文件
使用JDK的keytool工具
- keytool在jdk的bin目录下
- 生成数字文件
1 | keytool -genkeypair -alias serverkey -keypass 111111 -storepass 111111 -dname "C=CN,ST=SD,L=QD,O=xxx,OU=dev,CN=xxx.com" -keyalg RSA -keysize 2048 -validity 3650 -keystore D:\keystore\server.keystore |
storepass keystore 文件存储密码
keypass 私钥加解密密码
alias 实体别名(包括证书私钥)
dname 证书个人信息
keyalt 采用公钥算法,默认是DSA keysize 密钥长度(DSA算法对应的默认算法是sha1withDSA,不支持2048长度,此时需指定RSA)
validity 有效期
keystore 指定keystore文件

3,转换为p12格式
1 | keytool -importkeystore -srckeystore D:\keystore\server.keystore -destkeystore D:\keystore\server.p12 -srcalias serverkey -destalias serverkey -srcstoretype jks -deststoretype pkcs12 -srcstorepass 111111 -deststorepass 111111 -noprompt |

使用IText对pdf文件进行数字签名
1 | public static final String sourceFolder = "./src/test/resources/com/itextpdf/signatures/sign/SigningTest/"; |
1 | public void sign(String src //需要签章的pdf文件路径 |
效果如下:

可以查看下证书,会看到我们生成数字证书时的信息
