Maison  >  Questions et réponses  >  le corps du texte

php - Utiliser openssl_sign pour crypter le contenu et afficher des caractères tronqués

Lors de la connexion à l'API tierce, puisque le tiers utilise le cryptage Java, le contenu doit d'abord être traité en base64. Par conséquent, le contenu transmis est d'abord traité en base64, puis chiffré openssl_sign, mais le code renvoyé est tronqué.

$privary = file_get_contents('private_key.pem');
$pkeyid = openssl_pkey_get_private($privary);
$content = '<?xml version="1.0" encoding="UTF8"?><request><head><msgId>115454545454545hghghghgh5465ghghg</msgId><timeStamp>20160110103012304</timeStamp><session></session><userCode>a77b0ae7-af59-4</userCode></head><body><cityMsg><searchTxt>g</searchTxt><page>1</page><count>20</count></cityMsg></body></request>';

$content = base64_encode($content);
openssl_sign($content, $signature, $privary, "SHA256");

print $signature;

Voici le résultat :

mm|†Ñ±ù¼®²OW®W‰EdŽáWѤ{†Q&3tÎtþù¹¤5ŸJYLß,@±½Qlî†ÓûñB=ÑF͵OPÔZaîöÃý¯s\^¼žFOôâåä6µµ¬Js¤våaãSchq üî*ªo³¢3<‹adÿ«˜Lí™q.è    &ÂW¬b+…Çênƒy·“KM`–GrìmÈà”è#\ÕQ"½H™Wßr-CB8Ä\ lÅŵü34½˜–þæw÷ w"xåívwѯÎÄ*꾈Ñd0ÉÿíbÉ‹#V+­Ï×úÚë$JÀ†J=C™‹ë)öó

Le résultat de cryptage correct devrait être comme ceci :

bW0TF3yG0bH5vK6yA09XrleJRWSO4VfDkaR7AIZRJjN0znT+FvkSuaQ1n0pZBkzfLI1Asb1RbAjuhtP78UI90UbNtU9Q1Fph7vbDH/2vc1xevJ5GT/Ti5eQ2tbWsSnPCpHblYQTjU39jaHEN/O4qqm+zoggzEjyLYWT/q5hM7ZlxLgvoDAkmwlcbrGIrhcfqFG6DeZC3k0tNYMKWR3LsbcjgjZToI1zVUSK9SJmBV99yLUMOQjjEXBsgbMXFtR78MzS9mJb+5nf3Co13Injl7XZ30a/OxCrqvojRZDDJ/+1iyYsjVisUAa3P1/qP2uskSsCGSj0UQ5mL650TKfbzFg==
typechotypecho2702 Il y a quelques jours2971

répondre à tous(1)je répondrai

  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-06-19 09:09:12

    Que ce soit RSA,还是DESAES等加密算法,加密之后本质就是是ascii字符串(0x00-0xff),

    Si vous souhaitez visualiser ou transmettre, vous pouvez base64 encode

    Le décryptage nécessite d'abord base64 decode puis le décryptage

    répondre
    0
  • Annulerrépondre