Discussions
Categories
- 197K All Categories
- 2.5K Data
- 546 Big Data Appliance
- 1.9K Data Science
- 450.8K Databases
- 221.9K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 31 Multilingual Engine
- 552 MySQL Community Space
- 479 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.1K ORDS, SODA & JSON in the Database
- 556 SQLcl
- 4K SQL Developer Data Modeler
- 187.2K SQL & PL/SQL
- 21.4K SQL Developer
- 296.3K Development
- 17 Developer Projects
- 139 Programming Languages
- 293K Development Tools
- 110 DevOps
- 3.1K QA/Testing
- 646.1K Java
- 28 Java Learning Subscription
- 37K Database Connectivity
- 158 Java Community Process
- 105 Java 25
- 22.1K Java APIs
- 138.2K Java Development Tools
- 165.3K Java EE (Java Enterprise Edition)
- 19 Java Essentials
- 162 Java 8 Questions
- 86K Java Programming
- 81 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 205 Java User Groups
- 24 JavaScript - Nashorn
- Programs
- 468 LiveLabs
- 39 Workshops
- 10.2K Software
- 6.7K Berkeley DB Family
- 3.5K JHeadstart
- 5.7K Other Languages
- 2.3K Chinese
- 175 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 233 Portuguese
Java : how to create java.security.Key from .asc file?

I have to encrypt a file to pgp format. I have my public key in .asc format.
The cipher init() method needs a public key to be passed in. What is way to load that key from the file like this? In my case it is .asc file. And the details ablout the key file is described below:
I am getting an error: " java.security.spec.InvalidKeySpecException: java.security.InvalidKeyException: invalid key format " when I am trying to encrypt a file.
Here is my encrypt method:
public static CipherOutputStream encrypt(OutputStream outputStream, String publicKeyPath)
{
Cipher cipher;
Key publicKey = null;
try
{
cipher = Cipher.getInstance("RSA", "BC");
} catch (NoSuchAlgorithmException | NoSuchProviderException | NoSuchPaddingException e) {
String msg = "failed to create output stream";
System.out.println( msg + " : " + e.getMessage());
e.printStackTrace();
throw new RuntimeException( msg, e );
}
try {
publicKey = getPublicKey(publicKeyPath);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
} catch (InvalidKeyException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return ( new CipherOutputStream(outputStream, cipher));
}
I am getting error: java.security.spec.InvalidKeySpecException: java.security.InvalidKeyException: invalid key format
My getPublicKey method looks like :
public static PublicKey getPublicKey(String filename)
throws Exception {
File pubKeyFile = new File(filename);
DataInputStream dis = new DataInputStream(new FileInputStream(pubKeyFile));
byte[] pubKeyBytes = new byte[(int)pubKeyFile.length()];
dis.readFully(pubKeyBytes);
dis.close();
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
// decode public key
X509EncodedKeySpec pubSpec = new X509EncodedKeySpec(pubKeyBytes);
return keyFactory.generatePublic(pubSpec);
}
Public_key.asc looks like :
<span class="pun" style="color: #303336;">-----</span><span class="pln" style="color: #303336;">BEGIN PGP PUBLIC KEY BLOCK</span><span class="pun" style="color: #303336;">-----</span><span class="pln" style="color: #303336;"><br/> </span><span class="typ" style="color: #2b91af;">Version</span><span class="pun" style="color: #303336;">:</span><span class="pln" style="color: #303336;"> </span><span class="typ" style="color: #2b91af;">Encryption</span><span class="pln" style="color: #303336;"> </span><span class="typ" style="color: #2b91af;">Desktop</span><span class="pln" style="color: #303336;"> </span><span class="lit" style="color: #7d2727;">10.3</span><span class="pun" style="color: #303336;">.</span><span class="lit" style="color: #7d2727;">2</span><span class="pln" style="color: #303336;"> </span><span class="pun" style="color: #303336;">(</span><span class="typ" style="color: #2b91af;">Build</span><span class="pln" style="color: #303336;"> </span><span class="lit" style="color: #7d2727;">16127</span><span class="pun" style="color: #303336;">)</span><span class="pln" style="color: #303336;"><br/><br/> mQENBFYhXNoBCACgX</span><span class="pun" style="color: #303336;">/</span><span class="pln" style="color: #303336;">u03wm8cLqmTZiKGx6H</span><span class="pun" style="color: #303336;">/</span><span class="lit" style="color: #7d2727;">1ZUoBsfaDB2rdG2D8jYQzvaq4MA</span><span class="pln" style="color: #303336;"><br/> hZWBEVhA2BGKrNI</span><span class="pun" style="color: #303336;">+</span><span class="pln" style="color: #303336;">a2SDhKGAY4OK7aUZVAVG1bfQNVdNe80TbEF8g</span><span class="pun" style="color: #303336;">/</span><span class="pln" style="color: #303336;">wO2FreYPkb<br/> ojPtkwgyzsvb1BKwgRM1UMjkM5OWnhAPDhFDc39SFbmHLsXrURqFqJd9T3xzF6ty<br/><br/> </span><span class="pun" style="color: #303336;">................................................................</span><span class="pln" style="color: #303336;"><br/><br/><br/> D4WXvHpPXCJcwCBe</span><span class="pun" style="color: #303336;">+/</span><span class="lit" style="color: #7d2727;">81ZpjxlrLkUu8bO79jxZdKcI5ZRpmIe</span><span class="pun" style="color: #303336;">/</span><span class="typ" style="color: #2b91af;">VPJoDUVKLvl9n3</span><span class="pln" style="color: #303336;"><br/> </span><span class="typ" style="color: #2b91af;">ANvDJGdGcW3x6RyL9QOnoRDf6njimqcTm8UqImdLCz4TFdv94dvM4K0NOWuFdYal</span><span class="pln" style="color: #303336;"><br/> E9Q</span><span class="pun" style="color: #303336;">+</span><span class="pln" style="color: #303336;">U0Q7aiaWn</span><span class="pun" style="color: #303336;">+</span><span class="typ" style="color: #2b91af;">Kt</span><span class="pun" style="color: #303336;">+</span><span class="typ" style="color: #2b91af;">OYpd6</span><span class="pun" style="color: #303336;">++</span><span class="pln" style="color: #303336;">m7wnJRH</span><span class="pun" style="color: #303336;">/</span><span class="pln" style="color: #303336;">q0H69LIR9v3Td3udzOaxv</span><span class="pun" style="color: #303336;">/</span><span class="pln" style="color: #303336;">gzXF1BFuAS<br/> </span><span class="typ" style="color: #2b91af;">DQs6iA</span><span class="pun" style="color: #303336;">==</span><span class="pln" style="color: #303336;"><br/> </span><span class="pun" style="color: #303336;">=</span><span class="pln" style="color: #303336;">ckOV<br/> </span><span class="pun" style="color: #303336;">-----</span><span class="pln" style="color: #303336;">END PGP PUBLIC KEY BLOCK</span><span class="pun" style="color: #303336;">-----</span>
Here are the properties of this key:
Answers
-
I'd check your key against a public key checker (if you Google it, you'll find a couple). You might have invalid hidden characters etc
-
My Keys are good as I used org.bouncycastle.openpgp* lib to implement this earlier which worked perfectly fine until I tested with 10GB file to encrypt/decrypt. As this org.bouncycastle api holds data in memory after compress/de-compress, we saw java heap space error with that big file.Now we are trying javax.crypto.Cipher and got stuck with the issue described ( How to create the public key).
-
Yeah, you'll need to have a larger heap and move to G1 to support that heap size.