2016-10-24 2 views
0

Je suis assez nouveau à Java. J'ai un fichier plat où j'ai stocké mon mot de passe crypté à l'aide de l'utilitaire GPG d'Unix. Maintenant, je veux lire le fichier et obtenir le mot de passe dans une chaîne avant de se connecter à un système. J'ai lu le poste Getting GPG Decryption To Work In Java (Bouncy Castle) mais je ne peux pas utiliser le programme car il me donne l'erreur d'ajouter @ avant PGPSecretKey et de supprimer les jetons etc. Fondamentalement, je ne sais pas où mettre les méthodes java dans mon projet.GPG déchiffrer fichier plat à partir de Java

Ci-dessous mon code:

package jcpx.oracle.apps.gpg; 

import org.bouncycastle.apache.*; 
import org.bouncycastle.apache.bzip2.*; 
import org.bouncycastle.bcpg.*; 
import org.bouncycastle.bcpg.attr.*; 
import org.bouncycastle.bcpg.sig.*; 
import org.bouncycastle.openpgp.*; 

private PGPSecretKey readSecretKey(InputStream in) throws IOException, PGPException { 
in = PGPUtil.getDecoderStream(in); 
PGPSecretKeyRingCollection pgpSec = new PGPSecretKeyRingCollection(in, 
     new BcKeyFingerprintCalculator()); 

PGPSecretKey key = null; 
for (Iterator<PGPSecretKeyRing> it = pgpSec.getKeyRings(); key == null && it.hasNext();) { 
    PGPSecretKeyRing kRing = it.next(); 

    for (Iterator<PGPSecretKey> it2 = kRing.getSecretKeys(); key == null 
      && it2.hasNext();) { 
     PGPSecretKey k = it2.next(); 
     if ((keyId == null) && k.isSigningKey()) { 
      key = k; 
     } 
     if ((keyId != null) 
       && (Long.valueOf(keyId, 16).longValue() == (k.getKeyID() & MASK))) { 
      key = k; 
     } 
    } 
} 

if (key == null) { 
    throw new IllegalArgumentException("Can't find encryption key" 
      + (keyId != null ? " '" + keyId + "' " : " ") + "in key ring."); 
} 

return key; 
} 
+0

S'il vous plaît assurez-vous d'afficher les messages d'erreur _exact_ dans votre description du problème. Souvent, fournir un exemple petit, mais complet (et exécutable) aide à comprendre le problème. –

Répondre