मैं एक छोटे से परियोजना मैं शाम में निर्माण किया गया है के लिए ऐसा करने की जरूरत है।
function newPair (&$private, &$public, $passphrase=null) {
$res = openssl_pkey_new();
if ($res === false) {
throw new Exception ("Key generation failed: ".openssl_error_string());
return false;
}
// Sets private by reference
if (openssl_pkey_export ($res, $private, $passphrase) === false) {
throw new Exception ("Private key export failed: ".openssl_error_string());
return false;
}
// Array returns, contains "key" element.
$public = openssl_pkey_get_details($res);
if ($public === false) {
throw new Exception (openssl_error_string());
return false;
}
$public = $public["key"];
return true;
}
open_ssl_pkey_export() पदबंध जादू करता है:
हम निम्नलिखित एक नई कुंजी युग्म (सार्वजनिक/निजी) बनाता है। इसलिए हम पासफ्रेज को इस प्रकार बदल सकते हैं:
function changePassphrase ($private, $old, $new=null) {
$res = openssl_pkey_get_private ($private, $old);
if ($res === false) {
throw new Exception ("Loading private key failed: ".openssl_error_string());
return false;
}
if (openssl_pkey_export ($res, $result, $new) === false) {
throw new Exception ("Passphrase change failed: ".openssl_error_string());
return false;
}
return $result;
}
मुझे आशा है कि आप यहां जो कुछ भी कर चुके हैं उसका पालन कर सकते हैं ...! (जाहिर है अपवाद फेंक विशुद्ध रूप से वैकल्पिक है ... मैं बस अपना codebase से शब्दशः कोड खींच लिया गया है।)
changePassphrase() वर्तमान और नए पासफ्रेज के साथ साथ, एक स्ट्रिंग के रूप में निजी कुंजी ले जाता है। हम निजी कुंजी पर एक हैंडल पुनर्प्राप्त करने के लिए openssl_pkey_get_private() का उपयोग करते हैं, इसे पुराने पासफ्रेज़ से अनलॉक करते हैं।
(यह ध्यान देने योग्य है कि पासफ्रेज का उपयोग शाब्दिक रूप से निजी कुंजी को एन्क्रिप्ट करने के लिए किया जाता है, जो थोड़ा डबल-डच लग सकता है! [एन्क्रिप्शन कुंजी एन्क्रिप्ट करना ...?!] Openssl_pkey_get_private() false देता है अगर यह व्याख्या करने में विफल रहता है कुंजी - यानी अगर पासफ्रेज गलत है, और निजी कुंजी अमान्य मान को अस्वीकार करती है। समझ में आता है?)
पुराने पासफ्रेज़ के साथ निजी कुंजी अनलॉक करने के बाद, हम ओपनएसएसएल कुंजी हैंडल लेते हैं और इसे openssl_pkey_export पर पास करते हैं () - जैसे हम पहली जगह में इसे बनाने के बाद किया था (openssl_pkey_new के माध्यम से()) नए पासफ़्रेज़ ... और हे-Presto प्रदान करते हैं।
मुझे आशा है कि मेरे कोड उदाहरण सफाई से लिखा है, मैं, एक फैशन को समझते हैं और पालन करने के लिए आसान है कि में यह लिखने के लिए अनावश्यक "संपीड़न" और छोटी काटने के बिना कोशिश की है।
गुड लक!
मैं कोई लाभ नहीं हुआ लगातार दिन पर Freenode के ## पीएचपी चैनल में OpenSSL मेलिंग सूची पर कहा है, और है, लेकिन सभी। क्या मैं यहां गलत प्रश्न पूछ रहा हूं, या इस परिदृश्य में पासफ्रेज बदल रहा हूं, ओपनएसएसएल को सीधे PHP के सिस्टम() फ़ंक्शन के माध्यम से कॉल किए बिना संभव नहीं है? –
आप बिल्कुल ** नहीं हैं ** गलत सवाल पूछ रहे हैं! यह एक अच्छा सवाल है, और एक मैं थोड़ा चौंक गया हूं किसी ने जवाब नहीं दिया है (सीधे, PHP के लिए ओपनएसएसएल बाइंडिंग का उपयोग कर)। मुझे आशा है कि मेरा जवाब यह सब आपके लिए साफ़ कर देगा! – wally