Return-Path: Delivered-To: apmail-incubator-harmony-commits-archive@www.apache.org Received: (qmail 63784 invoked from network); 21 Jul 2006 10:03:38 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (209.237.227.199) by minotaur.apache.org with SMTP; 21 Jul 2006 10:03:38 -0000 Received: (qmail 49951 invoked by uid 500); 21 Jul 2006 10:03:29 -0000 Delivered-To: apmail-incubator-harmony-commits-archive@incubator.apache.org Received: (qmail 49886 invoked by uid 500); 21 Jul 2006 10:03:29 -0000 Mailing-List: contact harmony-commits-help@incubator.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: harmony-dev@incubator.apache.org Delivered-To: mailing list harmony-commits@incubator.apache.org Received: (qmail 49863 invoked by uid 99); 21 Jul 2006 10:03:29 -0000 Received: from asf.osuosl.org (HELO asf.osuosl.org) (140.211.166.49) by apache.org (qpsmtpd/0.29) with ESMTP; Fri, 21 Jul 2006 03:03:29 -0700 X-ASF-Spam-Status: No, hits=0.0 required=10.0 tests= X-Spam-Check-By: apache.org Received: from [209.237.227.198] (HELO brutus.apache.org) (209.237.227.198) by apache.org (qpsmtpd/0.29) with ESMTP; Fri, 21 Jul 2006 03:03:28 -0700 Received: from brutus (localhost [127.0.0.1]) by brutus.apache.org (Postfix) with ESMTP id 4F82D41000B for ; Fri, 21 Jul 2006 10:01:15 +0000 (GMT) Message-ID: <2746537.1153476075323.JavaMail.jira@brutus> Date: Fri, 21 Jul 2006 03:01:15 -0700 (PDT) From: "Mikhail Loenko (JIRA)" To: harmony-commits@incubator.apache.org Subject: [jira] Updated: (HARMONY-720) [classlib][security]java.security.Signature.initSign(PrivateKey key) throws unspecified NPE if key is invalid In-Reply-To: <9388253.1151671529771.JavaMail.jira@brutus> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-Virus-Checked: Checked by ClamAV on apache.org X-Spam-Rating: minotaur.apache.org 1.6.2 0/1000/N [ http://issues.apache.org/jira/browse/HARMONY-720?page=all ] Mikhail Loenko updated HARMONY-720: ----------------------------------- Component/s: Non-bug differences from RI (was: Classlib) > [classlib][security]java.security.Signature.initSign(PrivateKey key) throws unspecified NPE if key is invalid > ------------------------------------------------------------------------------------------------------------- > > Key: HARMONY-720 > URL: http://issues.apache.org/jira/browse/HARMONY-720 > Project: Harmony > Issue Type: Bug > Components: Non-bug differences from RI > Reporter: Vladimir Ivanov > Assigned To: Mikhail Loenko > Attachments: SignatureTest.patch > > > java.security.Signature.initSign(PrivateKey key) throws unspecified NPE if key is invalid. According to 1.5 spec method must throw only InvalidKeyException. > ======================= test.java ========================= > import java.security.*; > import java.security.interfaces.RSAPrivateCrtKey; > import java.math.BigInteger; > public class test { > public static void main (String[] args) { > try { > Signature sig = Signature.getInstance("SHA1withRSA"); > sig.initSign(new testRSAPrivateCrtKey()); > } catch (Exception e) { > e.printStackTrace(); > } > } > } > class testRSAPrivateCrtKey implements RSAPrivateCrtKey { > public BigInteger getCrtCoefficient() { > return null; > } > public BigInteger getPrimeP() { > return null; > } > public BigInteger getPrimeQ() { > return null; > } > public BigInteger getPrimeExponentP() { > return null; > } > public BigInteger getPrimeExponentQ() { > return null; > } > public BigInteger getPublicExponent() { > return null; > } > public BigInteger getPrivateExponent() { > return null; > } > public String getAlgorithm() { > return "AA"; > } > public String getFormat() { > return "AA"; > } > public byte[] getEncoded() { > return null; > } > public BigInteger getModulus() { > return null; > } > } > ======================================================= > Output: > C:\tmp\tmp17>C:\jrockit-jdk1.5.0-windows-ia32\bin\java.exe -showversion test > java version "1.5.0" > Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0-b64) > BEA WebLogic JRockit(R) (build dra-38972-20041208-2001-win-ia32, R25.0.0-75, GC: System optimized over throughput (initial strategy singleparpar)) > java.security.InvalidKeyException: Not an RSA key: AA > at sun.security.rsa.RSAKeyFactory.checkKey(RSAKeyFactory.java:103) > at sun.security.rsa.RSAKeyFactory.toRSAKey(RSAKeyFactory.java:76) > at sun.security.rsa.RSASignature.engineInitSign(RSASignature.java:90) > at sun.security.rsa.RSASignature.engineInitSign(RSASignature.java:84) > at java.security.Signature$Delegate.init(Signature.java:1076) > at java.security.Signature$Delegate.chooseProvider(Signature.java:1036) > at java.security.Signature$Delegate.engineInitSign(Signature.java:1100) > at java.security.Signature.initSign(Signature.java:485) > at test.main(test.java:9) > C:\tmp\tmp17>C:\harmony\trunk_0427\deploy\jdk\jre\bin\java.exe -showversion test > java version 1.5 (subset) > (c) Copyright 1991, 2006 The Apache Software Foundation or its licensors, as applicable. > java.lang.NullPointerException > at org.bouncycastle.crypto.engines.RSAEngine.init(Unknown Source) > at org.bouncycastle.crypto.encodings.PKCS1Encoding.init(Unknown Source) > at org.bouncycastle.jce.provider.JDKDigestSignature.engineInitSign(Unknown Source) > at java.security.Signature.initSign(Signature.java:223) > at test.main(test.java:9) -- This message is automatically generated by JIRA. - If you think it was sent incorrectly contact one of the administrators: http://issues.apache.org/jira/secure/Administrators.jspa - For more information on JIRA, see: http://www.atlassian.com/software/jira