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;
}
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. –