2017-07-11 12 views
7

में sec256k1 कुंजी मिलान करना मुझे ionux/phactor PHP लाइब्रेरी, और indutny/elliptic जेएस लाइब्रेरी को एकजुट करने में समस्या हो रही है।जेएस और PHP

एक लाइब्रेरी सर्वर पर एक लाइब्रेरी का उपयोग किया जा रहा है, दूसरा अमेज़ॅन लैम्ब्डा में नोडज के माध्यम से।

मैं PHP लाइब्रेरी के साथ एक कुंजी जोड़ी उत्पन्न करता हूं; sha256 हैश डेटा पर हस्ताक्षर करें और जेएसओएन आउटपुट के रूप में परिणाम सहेजें।

$ec = KeyManager::instance()->getECKeysByHash($k = '122e43fd75dd0492a259146ab5dfd5c6'); 

return $response = [ 
    'source' => [ 
     'message' => $m = 'asd', 
     'hash' => $h = hash('sha256', $m), 
     'hash_signed' => $ec->sign($h), 
    ], 
    'ec' => [ 
     'key' => $k, 
     'keys' => config(KeyManager::EC_DIR_NAME.'.'.$k) 
    ] 

]; 

आउटपुट:

{ 
    "source":{ 
     "message":"asd", 
     "hash":"688787d8ff144c502c7f5cffaafe2cc588d86079f9de88304c26b0cb99ce91c6", 
     "hash_signed":"30460221009a8c0c55ddc3ab3dc3b1e944a92c94fb215b7ed8ac332d398a6acb9d543a5d06022100e87f295c537fb2d14a52476e56b4c3a214be97e421510cbb46cb2059bed342bf" 
    }, 
    "ec":{ 
     "key":"122e43fd75dd0492a259146ab5dfd5c6", 
     "keys":{ 
     "private_key_hex":"0xde1a1c2734cc1e65b46946cfeb7cad28e48e8efbce5e36d859a4aa06ca9bb3f8", 
     "private_key_dec":"100459584715065215111848758376288522810407133161466091883119287856242863354872", 
     "public_key":"043876c88178bb7e386bbdb6325e201ec8e0e1ab75fc6c7713ed04051e029cb94b9d01c3b6aee0e6c5c92d7456f16667b08b4121526e97f5c704a19f7e9b3cd6c", 
     "public_key_compressed":"023876c88178bb7e386bbdb6325e201ec8e0e1ab75fc6c7713ed04051e029cb94b", 
     "public_key_x":"3876c88178bb7e386bbdb6325e201ec8e0e1ab75fc6c7713ed04051e029cb94b", 
     "public_key_y":"9d01c3b6aee0e6c5c92d7456f16667b08b4121526e97f5c704a19f7e9b3cd6c" 
     } 
    } 
}; 

मैं एक जे एस चर tests के उत्पादन को बचाया है, और अगर हैश पीएचपी पक्ष पर उत्पन्न जांच करते हुए, इस तरह से जे एस एल्गोरिथ्म के बराबर होती है:

var ecc = new EC('secp256k1'); 
var my_hash_word_array = CryptoJS.SHA256(tests.source.message); 
var my_hash = my_hash_word_array.toString(); 

console.log('hash equals:',tests.source.hash == my_hash); 

मैं इस मामले में बराबर हो सकता हूं!

var key = ecc.keyFromPublic(tests.ec.keys.public_key_compressed, 'hex'); // <<< problem line 
console.log('signOk:', key.verify(my_hash, tests.source.hash_signed)); 

परिणाम है "signOk: गलत"

अब, मैं अगर उत्पन्न पीएचपी पक्ष हस्ताक्षर tests.source.hash_signed (tests.source.hash से) जाना जाता है सार्वजनिक कुंजी जे एस का उपयोग कर से संबंधित जाँच करना चाहते हैं, क्यूं कर? मैं क्या गलत कर रहा हूं?

+0

PHP कोड मेरे अपने वर्ग रैपर \ इंटरफेस का उपयोग करें। लेकिन केवल php लाइब्रेरी के अंदर ही सही ढंग से काम करता है। जेएस कोड के अंदर जेएस रैपर ठीक काम करता है। तृतीय पक्षों से डेटा साझाकरण \ जांच के साथ कोई भी क्रिया -> php या php-> तृतीय पक्ष (विभिन्न प्लेटफार्म) – LINKeRxUA

+0

काम नहीं कर रहा है जेएस डबल बराबर रूपांतरण = "== "के बजाय" === "के साथ जांच करने के लिए। तो हो सकता है कि आपको यह देखने के लिए प्रकारों को रूपांतरित करने की आवश्यकता हो कि वे बराबर हैं या नहीं। –

उत्तर

1

मैं काफी कुछ समय बिताया है इस पर नज़र रखने की कोशिश कर रहा है, और मैं यकीन है कि आपकी समस्या का प्रमुख एन्कोडिंग के साथ क्या करना है कर रहा हूँ:

var key = ecc.keyFromPublic(tests.ec.keys.public_key_compressed, 'hex'); 

इस लाइन जाहिरा तौर पर एक हेक्साडेसिमल इनकोडिंग कुंजी की तलाश में है ।

अपने लोड मूल्यों को देखते हुए:

"public_key_compressed":"023876c88178bb7e386bbdb6325e201ec8e0e1ab75fc6c7713ed04051e029cb94b", 

public_key_compressed हेक्साडेसिमल एन्कोडिंग में नहीं है (संकेत: "0x" के साथ शुरू नहीं करता है)

आप हेक्साडेसिमल के रूप में इस मूल्य एन्कोड करने के लिए यह सुनिश्चित करना चाहिये और पुनः प्रयास करें।

+0

ठीक है। मैं कोशिश करूंगा और प्रतिक्रिया देउंगा! आपके प्रतिक्रिया के लिए धन्येवाद! – LINKeRxUA

संबंधित मुद्दे