DotNetCore.SKIT.FlurlHttpCl.../docs/WechatTenpayV3/Advanced_ResponseSignatureVerification.md
2021-06-07 00:32:04 +08:00

1.6 KiB

如何验证微信响应签名?


请先自行阅读:

《微信支付开发者文档 - 开发指南:签名验证》

《微信支付开发者文档 - 平台证书:更新指引》

本库已经封装了 QueryCertificatesAsync() 方法,供开发者获取微信支付平台证书。

每个响应对象均包含 WechatpayTimestampWechatpayNonceWechatpaySignatureWechatpaySerial 等几个公共字段,你可根据官方文档的规则利用本库提供的 RSAUtility 工具类自行进行签名验证。

同时,本库也内置了验证签名的的方法,具体用法可以参考项目目录下的 test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/WechatTenpayResponseVerificationTests.cs 文件给出的测试用例。

需要注意的是,微信支付平台提供的是 PEM 格式的密钥文件,分为以下几种:

  • -----BEGIN PRIVATE KEY----- 开头、 -----END PRIVATE KEY----- 结尾的是 PKCS#8 私钥文件。

  • -----BEGIN PUBLIC KEY----- 开头、 -----END PUBLIC KEY----- 结尾的是 PKCS#8 公钥文件。

  • -----BEGIN CERTIFICATE----- 开头、 -----END CERTIFICATE----- 结尾的是 CER 证书文件。

QueryCertificatesAsync() 方法返回的结果是 CER 证书,验证签名时需要先通过 RSAUtility 工具类导出 PKCS#8 公钥,再进行签名验证;当然,RSAUtility 也封装了直接通过 CER 证书验证签名的方法。