- 論壇徽章:
- 0
|
我現(xiàn)在的一個(gè)項(xiàng)目需要用C++寫的COM組件加密一串字符串,保存密鑰到MYSQL數(shù)據(jù)庫(kù),然后用PHP解密出原文
現(xiàn)在的關(guān)鍵的問(wèn)題就是密鑰的問(wèn)題。。。C++下得到并保存的密鑰不能在PHP中使用
在C++中,密鑰是這樣生成出來(lái)的
- m_pRsa = RSA_new();
- m_pRsa = RSA_generate_key(m_rsa_bits,RSA_F4,NULL,NULL);
- len = i2d_RSAPublicKey(m_pRsa, &Pt); //得到公鑰,然后我會(huì)把公鑰保存到MYSQL數(shù)據(jù)庫(kù)中,私鑰也是這么保存的。。
- len = i2d_RSAPrivateKey(m_pRsa, &Pt);
復(fù)制代碼
現(xiàn)在在PHP中。。
我從MYSQL數(shù)據(jù)庫(kù)中讀出密鑰到$RealPubKey。。
然后這樣調(diào)用
openssl_public_encrypt($message,$encoded,$RealPubKey);
但是這樣是錯(cuò)誤的。
Warning: openssl_public_encrypt(): key parameter is not a valid public key in c:\program files\easyphp1-8\www\4.php on line 46
這也許是我對(duì)密鑰的理解不對(duì)造成的。。。。我不知道openssl_public_encrypt這個(gè)函數(shù)所需要的密鑰應(yīng)該是怎樣的格式。?戳艘恍┦纠a,但那些都是從一個(gè)格式為crt的文件里讀取的密鑰信息,這和我目前這個(gè)項(xiàng)目有不一樣的地方。。
在PHP中使用OPENSSL,好像沒(méi)有和以下C++語(yǔ)句等效的代碼。。PHP的OPENSSL擴(kuò)展中,似乎都沒(méi)有struct RSA這個(gè)結(jié)構(gòu)體來(lái)保存密鑰信息。。
m_pRsa = RSA_new();
m_pRsa = d2i_RSAPublicKey(NULL, &Pt, KeyDataLen); //設(shè)置公鑰
m_pRsa = d2i_RSAPrivateKey(NULL, &Pt, KeyDataLen);設(shè)置私鑰
我應(yīng)該怎樣保存密鑰才能使得C++程序和PHP程序可以互相加解密呢。。。 |
|