Certificate Downloader 是 Java 微信支付 APIv3 平台证书的命令行下载工具。该工具可从 https://api.mch.weixin.qq.com/v3/certificates
接口获取商户可用证书,并使用 APIv3 密钥 和 AES_256_GCM 算法进行解密,并把解密后证书下载到指定位置。
该工具使用了 wechatpay-apache-httpclient、Maven、picocli、gson、lombok 等库。
该工具已经通过 Maven 打包成 CertificateDownloader.jar,可在 release 中下载。
下载 jar 包后,如果你没有证书,第一次下载证书的命令如下,具体说明请看 常见问题-第一次下载证书:
java -jar CertificateDownloader.jar -k ${apiV3key} -m ${mchId} -f ${mchPrivateKeyFilePath} -s ${mchSerialNo} -o ${outputFilePath}
如果你已有微信支付平台证书,完整命令如:
java -jar CertificateDownloader.jar -k ${apiV3key} -m ${mchId} -f ${mchPrivateKeyFilePath} -s ${mchSerialNo} -o ${outputFilePath} -c ${wechatpayCertificateFilePath}
必需参数有:
-f <privateKeyFilePath>
,商户API私钥文件路径-k <apiV3Key>
,证书解密的密钥-m <merchantId>
,商户号-o <outputFilePath>
,保存证书的路径-s <merchantSerialNo>
,商户API证书的序列号非必需参数有:
-c <wechatpayCertificatePath>
,微信支付平台证书的路径。如果你还没有证书,请先不传该参数。你还可以运行 java -jar CertificateDownloader.jar -h
,查看帮助:
工具做了以下安全措施:
下载证书后,如果仍然担心证书出错,可:
使用 openssl 工具,通过证书信任链验证平台证书:
首先,从微信支付商户平台下载平台证书信任链 CertTrustChain.p7b,并将它转换为 pem 证书格式:
openssl pkcs7 -print_certs -in CertTrustChain.p7b -inform der -out CertTrustChain.pem
然后,-CAfile file 指定受信任的证书,验证下载的平台证书:
openssl verify -verbose -CAfile ./CertTrustChain.pem ./WeChatPayPlatform.pem
对于微信支付的应答,需要使用平台证书来进行验签;但平台证书只能通过 获取平台证书接口 下载,所以当第一次去获取证书时,会出现个“死循环”。
为解决这个“死循环”,可以临时跳过验签,来获得证书。也就是说可以不提供微信支付证书参数(-c 参数)来下载,在下载得到证书后,工具会使用下载得到的证书对报文的签名进行验证。
第一次下载证书后,我们强烈建议参考如何通过证书信任链验证平台证书,验证证书的真实性。
有的: