0

我现在正在开发 android 上的数字签名应用程序。

但是,我未能制作 apk 文件,因为 eclipse 显示以下消息

[2013-01-27 20:43:25 - BlowfishCipher] Dx 意外顶级异常: java.lang.IllegalArgumentException:已添加:Lorg/bouncycastle/mozilla/SignedPublicKeyAndChallenge;

[2013-01-27 20:43:25 - BlowfishCipher] Dx 在 com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:123) [2013-01-27 20:43:25 - BlowfishCipher] Dx 在 com.android.dx.dex.file.DexFile.add(DexFile.java:163)

我知道错误消息表明重复的 jar 文件,但我不知道如何解决它,因为重复的 jar (Lorg/bouncycastle/mozilla/SignedPublicKeyAndChallenge;) 是 bouncy caslte 库的核心文件。

并且以下 java 代码显示没有语法错误,但它导致java.lang.IllegalArgumentException: 已添加异常

package exam.blowfishcipher;

import java.io.FileWriter;
import java.io.OutputStreamWriter;
import java.security.KeyPair;
import java.security.SecureRandom;
import javax.security.auth.x500.X500Principal;
import org.bouncycastle.jce.PKCS10CertificationRequest;
import org.bouncycastle.openssl.PEMWriter;
import android.os.Environment;
import chapter6.PKCS10ExtensionExample;



public class PKCS10Generater
{
    public static PKCS10CertificationRequest generateRequest(
            KeyPair pair)
            throws Exception

            {           
             return new PKCS10CertificationRequest(
                     "SHA256withRSA",
                     new X500Principal("CN=Test CA Certificate"),
                     //new X500Principal("CN=end"),
                     pair.getPublic(),
                     null,
                     pair.getPrivate());
            }

    public static void pemEncodeToFile(String filename, Object obj, char[] password)     throws Exception{
        PEMWriter pw = new PEMWriter(new FileWriter(filename));
           if (password != null && password.length > 0) {
               pw.writeObject(obj, "DESEDE", password, new SecureRandom());
           } else {
               pw.writeObject(obj);
           }
           pw.flush();
           pw.close();
    }

    public static void reqGen() throws Exception
    {
        //create the keys
        /*
        KeyPairGenerator kpGen = KeyPairGenerator.getInstance("RSA", "BC");
        //KeyPairGenerator kpGen = KeyPairGenerator.getInstance()

        kpGen.initialize(512, chapter4.Utils.createFixedRandom());

        KeyPair pair=kpGen.generateKeyPair();
        */
        //PKCS10CertificationRequest request = generateRequest(pair);

        KeyPair pair = chapter8.Utils.generateRSAKeyPair();
        PKCS10CertificationRequest request = PKCS    10ExtensionExample.generateRequest(pair);


        pemEncodeToFile(Environment.getExternalStorageDirectory()+"pkcs10.req",     request, null);
        PEMWriter pemWrt = new PEMWriter( new OutputStreamWriter(System.out));
        pemWrt.writeObject(request);
        pemWrt.close();     
    }


}
4

1 回答 1

1

Android 已经在系统中包含 BouncyCastle,这就是为什么您在尝试再次添加它时会收到错误的原因(在最近的版本中,它实际上是在com.android.org.bouncycastle或类似的版本中,所以理论上您不应该收到错误)。如果你想将它包含在你的项目中,你必须重命名 BC 的包(使用 jarjar 等)。SpongyCastle 已经为您完成了这项工作。尝试使用它而不是常规的 BC jar。

https://github.com/rtyley/spongycastle

于 2013-01-28T02:07:57.107 回答