支付宝当面付的验证签名的坑

Posted 虚心使人进步

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了支付宝当面付的验证签名的坑相关的知识,希望对你有一定的参考价值。

生成签名时
openssl_get_privatekey

$priKey = "-----BEGIN RSA PRIVATE KEY-----\n" .
wordwrap($priKey, 64, "\n", true) .
"\n-----END RSA PRIVATE KEY-----";
$res = openssl_get_privatekey($priKey);

========

验证签名时
如果上传的文件就是支付宝后台下载的公钥(不带头尾的一行字符串),
那不需要再用
openssl_get_publickey
获取一次了。。
$res = "-----BEGIN PUBLIC KEY-----\n" .
wordwrap($pubKey, 64, "\n", true) .
"\n-----END PUBLIC KEY-----";
file_put_contents(HOME_DIR.‘/pay_alipayqrcode_callback.txt‘,date("Y-m-d H:i:s")."-pubKey:"."\r\n".var_export($res,true)."\r\n",FILE_APPEND);
//$res = openssl_get_publickey($pubKey);不需要再获取一次了。。

openssl_get_publickey适用于文件如下格式的
格式如这样的

-----BEGIN CERTIFICATE-----
MIICMTCCAZqgAwIBAgIKe5fKECdaAADZnTANBgkqhkiG9w0BAQUFADAcMQwwCgYD
VQQDEwNBQkMxDDAKBgNVBAoTA0FCQzAeFw0wNDAxMDUwNTQ5NDRaFw0yMzA4MTEw
NTM4NDlaMEExGDAWBgNVBAMTD01haW5TZXJ2ZXIuMDAwMTEXMBUGA1UECxMOUGF5
bWVudEdhdGV3YXkxDDAKBgNVBAoTA0FCQzCBnzANBgkqhkiG9w0BAQEFAAOBjQAw
gYkCgYEA//+Bv7geZqme6BCLboRzBNIlotyQ0qnaZjxRwjHM14SvjmiQK1+lJ4lJ
2RQFOIkakr7zDvscqs7HyShP3LnPK9c9nsIypM0YOtp/LdqmxqmOcBoB6Z43WJp5
0JMaC0w1UBEumX+wtPaa4JsoE99SEEQbJ29T+XFBLsvStT8DjRECAwEAAaNVMFMw
QAYDVR0fBDkwNzA1oDOgMaQvMC0xDzANBgNVBAMTBmNybDE4NjEMMAoGA1UECxMD
Y3JsMQwwCgYDVQQKEwNBQkMwDwYDVR1jBAgDBgD/AAAAADANBgkqhkiG9w0BAQUF
AAOBgQCZtKSPwnI+SMAu4RFUVIgRd/JRD45hqjMuK9Lux96sylRTwUJrn+0xj4P1
RXuKiMG/ldka8REsnCv7kX+OyEAAfN6xb1p+lykrJk+YvqJqPRkBhNVLoQostzdZ
wbUrApnELD+xLm0F6BRK/zRcz0H+2kI8L34OwOXm8NVXLnNF3Q==
-----END CERTIFICATE-----

以上是关于支付宝当面付的验证签名的坑的主要内容,如果未能解决你的问题,请参考以下文章

支付宝当面付怎么用,支付宝当面支付功能详解

支付宝当面付Demo测试

利用PBFunc在Powerbuilder中支付宝当面付功能

支付宝异步回调验证签名的那些走过的坑

Spring Boot入门教程(三十六):支付宝集成-当面付

支付宝扫码支付