2015-01-15 240 views
0

我是Android新手,我正在开发基于客户端服务器的应用程序。在这里我需要使用RSA算法进行加密/解密。将PHP生成的公钥转换为Java公钥

的情况是: 1.Server必须创建一个私有/公共密钥对(PHP)和发送公钥客户端(Android应用程序) 2,客户端应该使用公共密钥来加密数据并发送至服务器 3.现在的服务器必须使用私钥解密。

在PHP中,我使用'PhpSecLib'来创建密钥对。

这是编码:

Server.php:

<?PHP 
include 'Crypt/RSA.php'; 
$rsa = new Crypt_RSA(); 
extract($rsa->createKey(1024)); 
echo $publickey; 
?> 

生成的公钥:

MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDLz4yAo1FTOLc6nijBCTv5iVnW F6MxCeM5 + RXY + 29AXcpMWhlM9oES3ESIfWw6OzrrENDyqwY + kVzCj2bWYnEAyJXs WOpvqT2XSCPplwZOnQQGm + DnAYJXEeOfgU5DI63fwdiGv4M2 ph1VMMe6684sBZu1 HhJHuhsX2eibBR0/lQIDAQAB

现在在Java中,我成功地收到了这个公钥并存储在一个String中。

编码:

protected String doInBackground(Void... params) 
{ 
    try 
    { 
    URL url=new URL("http://10.0.2.2/Samples/Server.php"); 
    URLConnection con=url.openConnection(); 
    con.setDoOutput(true); 
    BufferedReader ip=new BufferedReader(new InputStreamReader(con.getInputStream())); 
    String tmp,res=""; 

    while((tmp=ip.readLine())!=null) 
    { 
     res+=tmp; 

    } 

    return res; //res contains the public key 


    } 
    catch(Exception e) 
    { 
     return new String("Exception : "+e.getMessage()); 
    } 

} 

我在Java中使用充气城堡提供商(bcprov-jdk15on-151)。

现在我不知道如何将此字符串转换为RSA公钥。

请提供一些代码片段?如果代码需要改进和更正,请纠正它。

谢谢...

回答

1

假设你正确下载你的钥匙,你可以用你的钥匙在base 64 encoding产生与后续的代码java.security.PublicKey

import java.security.KeyFactory; 
import java.security.PublicKey; 
import java.security.spec.X509EncodedKeySpec; 

import javax.crypto.Cipher; 

import org.bouncycastle.jce.provider.BouncyCastleProvider; 
import org.bouncycastle.util.encoders.Base64; 

public class ParseRsaPublicKey { 

    public static void main(String[] args) throws Exception { 
     String yourKeyB64 = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDLz4yAo1FTOLc6nijBCTv5iVnW\n"+ 
       "F6MxCeM5+RxY+29AXcpMWhlM9oES3ESIfWw6OzrrENDyqwY+kVzCj2bWYnEAyJXs\n"+ 
       "WOpvqT2XSCPplwZOnQQGm+DnAYJXEeOfgU5DI63fwdiGv4M2ph1VMMe6684sBZu1\n"+ 
       "HhJHuhsX2eibBR0/lQIDAQAB"; 
     // create the key factory 
     KeyFactory kFactory = KeyFactory.getInstance("RSA", new BouncyCastleProvider()); 
     // decode base64 of your key 
     byte yourKey[] = Base64.decode(yourKeyB64); 
     // generate the public key 
     X509EncodedKeySpec spec = new X509EncodedKeySpec(yourKey); 
     PublicKey publicKey = (PublicKey) kFactory.generatePublic(spec); 
     // now you can for example cipher some data with your key 
     Cipher cipher = Cipher.getInstance("RSA"); 
     cipher.init(Cipher.ENCRYPT_MODE, publicKey); 
     byte[] cipherData = cipher.doFinal("someData".getBytes()); 
     System.out.println(new String(cipherData)); 
    } 

} 

希望这有助于

+0

谢谢老兄..得到它.. – Jeeva 2015-01-23 10:44:54

+0

@Jeeva欢迎:)如果答案可以帮助你记得接受它:) – albciff 2015-01-23 10:49:48