Récemment, j'ai travaillé sur la fenêtre du service Alipay pour un client et j'ai rencontré une erreur :
Attention : openssl_sign() [function.openssl-sign] : algorithme de signature inconnu dans
<.>
Après vérification, j'ai constaté que l'environnement PHP sur mon serveur prend en charge openssl_sign() mais ne prend pas en charge des paramètres tels que OPENSSL_ALGO_SHA256. Après avoir demandé au patron, j'ai trouvé que ce paramètre n'est pris en charge que dans php5.4.8 ou supérieur, et les versions inférieures, j'ai utilisé SHA256, alors je l'ai essayé et je l'ai obtenu !
La raison de l'erreur est que le fichier AopClient.php dans la démo d'Alipay utilise une telle instruction :
if ("RSA2" == $signType) {
openssl_sign($data, $sign, $res,OPENSSL_ALGO_SHA256);
} else {
openssl_sign($data, $sign , $ res);
}
La solution est de changer OPENSSL_ALGO_SHA256 en SHA256
if ( "RSA2" == $signType) {
openssl_sign($data, $sign, $res,SHA256);
} else {
openssl_sign($data, $sign, $res);
}
Remarque : Il y a trois endroits dans ce fichier, vous devez les modifier tous!
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!