Getting different result (cyphertext) while using AES in Java and golangDifferences between HashMap and Hashtable?Is Java “pass-by-reference” or “pass-by-value”?Does a finally block always get executed in Java?What is the difference between public, protected, package-private and private in Java?How do I read / convert an InputStream into a String in Java?When to use LinkedList over ArrayList in Java?How do I generate random integers within a specific range in Java?How do I convert a String to an int in Java?Creating a memory leak with JavaWhy is subtracting these two times (in 1927) giving a strange result?
Should I self-publish my novella on Amazon or try my luck getting publishers?
Japanese equivalent of a brain fart
Half-rock- half-forest-gnome
Why can I log in to my Facebook account with a misspelled email/password?
Is TEXT to VARCHAR(MAX) an implicit conversion?
Should I take out a personal loan to pay off credit card debt?
Why does putting a dot after the URL remove login information?
How to help new students accept function notation
Was there ever a difference between 'volo' and 'volo'?
Did silent film actors actually say their lines or did they simply improvise “dialogue” while being filmed?
Did WWII Japanese soldiers engage in cannibalism of their enemies?
What are these mathematical groups in U.S. universities?
How would I as a DM create a smart phone-like spell/device my players could use?
Why should public servants be apolitical?
What does VB stand for?
Validation and verification of mathematical models
Double blind peer review when paper cites author's GitHub repo for code
polynomial, find the sum of the inverse roots of this equation.
tikz-3dplot: angle-placed cones in a sphere
Short story about a teenager who has his brain replaced with a microchip (Psychological Horror)
Sets A such that A+A contains the largest set [0,1,..,t]
If there were no space agencies, could a person go to space?
Can I say "if a sequence is not bounded above, then it is divergent to positive infinity" without explicitly saying it's eventually increasing?
Does the United States guarantee any unique freedoms?
Getting different result (cyphertext) while using AES in Java and golang
Differences between HashMap and Hashtable?Is Java “pass-by-reference” or “pass-by-value”?Does a finally block always get executed in Java?What is the difference between public, protected, package-private and private in Java?How do I read / convert an InputStream into a String in Java?When to use LinkedList over ArrayList in Java?How do I generate random integers within a specific range in Java?How do I convert a String to an int in Java?Creating a memory leak with JavaWhy is subtracting these two times (in 1927) giving a strange result?
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;
I am trying to replicate the java code for AES encryption into Golang.
However I am not getting the same output in golang
I tried below code:
Java Code:
package EncryptionTest;
import java.security.Key;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
cipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Java code output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: vSmrgH3qU+qEq+3ui0YvwCa6PDBcMyhgOlbh3+zzM+cON6feLk2u1iPW7lITD3vn
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
Golang Code:
package main
import (
"crypto/aes"
"crypto/cipher"
"encoding/base64"
"fmt"
)
const NONCESIZE = 12
func main()
key := []byte("0123456789012345")
plaintext := []byte("AES Symmetric Encryption Decryption")
block, err := aes.NewCipher(key)
if err != nil
panic(err.Error())
nonce := make([]byte, NONCESIZE)
aesgcm, err := cipher.NewGCM(block)
if err != nil
panic(err.Error())
ciphertext := aesgcm.Seal(nil, nonce, plaintext, nil)
fmt.Println("Encrypted Text is : ", base64.StdEncoding.EncodeToString(ciphertext))
Golang Code output:
Encrypted Text is : 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
java go aes encryption-symmetric
add a comment |
I am trying to replicate the java code for AES encryption into Golang.
However I am not getting the same output in golang
I tried below code:
Java Code:
package EncryptionTest;
import java.security.Key;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
cipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Java code output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: vSmrgH3qU+qEq+3ui0YvwCa6PDBcMyhgOlbh3+zzM+cON6feLk2u1iPW7lITD3vn
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
Golang Code:
package main
import (
"crypto/aes"
"crypto/cipher"
"encoding/base64"
"fmt"
)
const NONCESIZE = 12
func main()
key := []byte("0123456789012345")
plaintext := []byte("AES Symmetric Encryption Decryption")
block, err := aes.NewCipher(key)
if err != nil
panic(err.Error())
nonce := make([]byte, NONCESIZE)
aesgcm, err := cipher.NewGCM(block)
if err != nil
panic(err.Error())
ciphertext := aesgcm.Seal(nil, nonce, plaintext, nil)
fmt.Println("Encrypted Text is : ", base64.StdEncoding.EncodeToString(ciphertext))
Golang Code output:
Encrypted Text is : 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
java go aes encryption-symmetric
Java's getBytes is not deterministic but depends on the default charset.
– Volker
Mar 27 at 6:13
AES use random initial vector for encryption. Every call generates random initial vector and this cause different encrypted text.
– Dogushan KAYA
Mar 27 at 7:18
@DogushanKAYA : The code which I pasted here, generating the same encrypted text.
– Prashant Gupta
Mar 27 at 8:57
add a comment |
I am trying to replicate the java code for AES encryption into Golang.
However I am not getting the same output in golang
I tried below code:
Java Code:
package EncryptionTest;
import java.security.Key;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
cipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Java code output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: vSmrgH3qU+qEq+3ui0YvwCa6PDBcMyhgOlbh3+zzM+cON6feLk2u1iPW7lITD3vn
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
Golang Code:
package main
import (
"crypto/aes"
"crypto/cipher"
"encoding/base64"
"fmt"
)
const NONCESIZE = 12
func main()
key := []byte("0123456789012345")
plaintext := []byte("AES Symmetric Encryption Decryption")
block, err := aes.NewCipher(key)
if err != nil
panic(err.Error())
nonce := make([]byte, NONCESIZE)
aesgcm, err := cipher.NewGCM(block)
if err != nil
panic(err.Error())
ciphertext := aesgcm.Seal(nil, nonce, plaintext, nil)
fmt.Println("Encrypted Text is : ", base64.StdEncoding.EncodeToString(ciphertext))
Golang Code output:
Encrypted Text is : 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
java go aes encryption-symmetric
I am trying to replicate the java code for AES encryption into Golang.
However I am not getting the same output in golang
I tried below code:
Java Code:
package EncryptionTest;
import java.security.Key;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
cipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Java code output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: vSmrgH3qU+qEq+3ui0YvwCa6PDBcMyhgOlbh3+zzM+cON6feLk2u1iPW7lITD3vn
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
Golang Code:
package main
import (
"crypto/aes"
"crypto/cipher"
"encoding/base64"
"fmt"
)
const NONCESIZE = 12
func main()
key := []byte("0123456789012345")
plaintext := []byte("AES Symmetric Encryption Decryption")
block, err := aes.NewCipher(key)
if err != nil
panic(err.Error())
nonce := make([]byte, NONCESIZE)
aesgcm, err := cipher.NewGCM(block)
if err != nil
panic(err.Error())
ciphertext := aesgcm.Seal(nil, nonce, plaintext, nil)
fmt.Println("Encrypted Text is : ", base64.StdEncoding.EncodeToString(ciphertext))
Golang Code output:
Encrypted Text is : 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
java go aes encryption-symmetric
java go aes encryption-symmetric
asked Mar 27 at 5:59
Prashant GuptaPrashant Gupta
81 bronze badge
81 bronze badge
Java's getBytes is not deterministic but depends on the default charset.
– Volker
Mar 27 at 6:13
AES use random initial vector for encryption. Every call generates random initial vector and this cause different encrypted text.
– Dogushan KAYA
Mar 27 at 7:18
@DogushanKAYA : The code which I pasted here, generating the same encrypted text.
– Prashant Gupta
Mar 27 at 8:57
add a comment |
Java's getBytes is not deterministic but depends on the default charset.
– Volker
Mar 27 at 6:13
AES use random initial vector for encryption. Every call generates random initial vector and this cause different encrypted text.
– Dogushan KAYA
Mar 27 at 7:18
@DogushanKAYA : The code which I pasted here, generating the same encrypted text.
– Prashant Gupta
Mar 27 at 8:57
Java's getBytes is not deterministic but depends on the default charset.
– Volker
Mar 27 at 6:13
Java's getBytes is not deterministic but depends on the default charset.
– Volker
Mar 27 at 6:13
AES use random initial vector for encryption. Every call generates random initial vector and this cause different encrypted text.
– Dogushan KAYA
Mar 27 at 7:18
AES use random initial vector for encryption. Every call generates random initial vector and this cause different encrypted text.
– Dogushan KAYA
Mar 27 at 7:18
@DogushanKAYA : The code which I pasted here, generating the same encrypted text.
– Prashant Gupta
Mar 27 at 8:57
@DogushanKAYA : The code which I pasted here, generating the same encrypted text.
– Prashant Gupta
Mar 27 at 8:57
add a comment |
1 Answer
1
active
oldest
votes
In the go code, you are using AES in GCM mode with 12 bytes of zero as IV, but in java code you are using default mode of AES which is not the same in different java versions.
By using GCM mode(Provided in BouncyCastle) and setting the same IV(12 bytes of zero) I got same output:
package EncryptionTest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.security.Key;
import java.security.Security;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Security.addProvider(new BouncyCastleProvider());
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES/GCM/NoPadding", "BC");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivParameterSpec);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.DECRYPT_MODE, secretKey, ivParameterSpec);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
Here I want to know what is the default mode which my java code is using and how to replicate the same in golang.
– Prashant Gupta
Mar 27 at 8:59
@PrashantGupta relying on default mode is risky. You should set it explicitly. As I said, you can use GCM in golang and java but if you don't want to use bouncy castle, you can use CBC mode in both languages.
– Hamidreza Kalantari
Mar 27 at 9:05
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55370699%2fgetting-different-result-cyphertext-while-using-aes-in-java-and-golang%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
In the go code, you are using AES in GCM mode with 12 bytes of zero as IV, but in java code you are using default mode of AES which is not the same in different java versions.
By using GCM mode(Provided in BouncyCastle) and setting the same IV(12 bytes of zero) I got same output:
package EncryptionTest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.security.Key;
import java.security.Security;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Security.addProvider(new BouncyCastleProvider());
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES/GCM/NoPadding", "BC");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivParameterSpec);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.DECRYPT_MODE, secretKey, ivParameterSpec);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
Here I want to know what is the default mode which my java code is using and how to replicate the same in golang.
– Prashant Gupta
Mar 27 at 8:59
@PrashantGupta relying on default mode is risky. You should set it explicitly. As I said, you can use GCM in golang and java but if you don't want to use bouncy castle, you can use CBC mode in both languages.
– Hamidreza Kalantari
Mar 27 at 9:05
add a comment |
In the go code, you are using AES in GCM mode with 12 bytes of zero as IV, but in java code you are using default mode of AES which is not the same in different java versions.
By using GCM mode(Provided in BouncyCastle) and setting the same IV(12 bytes of zero) I got same output:
package EncryptionTest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.security.Key;
import java.security.Security;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Security.addProvider(new BouncyCastleProvider());
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES/GCM/NoPadding", "BC");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivParameterSpec);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.DECRYPT_MODE, secretKey, ivParameterSpec);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
Here I want to know what is the default mode which my java code is using and how to replicate the same in golang.
– Prashant Gupta
Mar 27 at 8:59
@PrashantGupta relying on default mode is risky. You should set it explicitly. As I said, you can use GCM in golang and java but if you don't want to use bouncy castle, you can use CBC mode in both languages.
– Hamidreza Kalantari
Mar 27 at 9:05
add a comment |
In the go code, you are using AES in GCM mode with 12 bytes of zero as IV, but in java code you are using default mode of AES which is not the same in different java versions.
By using GCM mode(Provided in BouncyCastle) and setting the same IV(12 bytes of zero) I got same output:
package EncryptionTest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.security.Key;
import java.security.Security;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Security.addProvider(new BouncyCastleProvider());
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES/GCM/NoPadding", "BC");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivParameterSpec);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.DECRYPT_MODE, secretKey, ivParameterSpec);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
In the go code, you are using AES in GCM mode with 12 bytes of zero as IV, but in java code you are using default mode of AES which is not the same in different java versions.
By using GCM mode(Provided in BouncyCastle) and setting the same IV(12 bytes of zero) I got same output:
package EncryptionTest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.security.Key;
import java.security.Security;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
public class EncryptionDecryptionAES
static Cipher cipher;
public static void main(String[] args) throws Exception
Security.addProvider(new BouncyCastleProvider());
Key secretKey;
secretKey = (Key)new SecretKeySpec("0123456789012345".getBytes(), "AES");
cipher = Cipher.getInstance("AES/GCM/NoPadding", "BC");
String plainText = "AES Symmetric Encryption Decryption";
System.out.println("Plain Text Before Encryption: " + plainText);
String encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text After Encryption: " + encryptedText);
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text After Decryption: " + decryptedText);
public static String encrypt(String plainText, Key secretKey) throws Exception
byte[] plainTextByte = plainText.getBytes();
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivParameterSpec);
byte[] encryptedByte = cipher.doFinal(plainTextByte);
Base64.Encoder encoder = Base64.getEncoder();
String encryptedText = encoder.encodeToString(encryptedByte);
return encryptedText;
public static String decrypt(String encryptedText, Key secretKey) throws Exception
Base64.Decoder decoder = Base64.getDecoder();
byte[] encryptedTextByte = decoder.decode(encryptedText);
byte[] iv = new byte[12];
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);
cipher.init(Cipher.DECRYPT_MODE, secretKey, ivParameterSpec);
byte[] decryptedByte = cipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);
return decryptedText;
Output:
Plain Text Before Encryption: AES Symmetric Encryption Decryption
Encrypted Text After Encryption: 7UMh49c5Wqb2BzlttKBEnq5g4fxMK9oJs1EUDIgWzVwlY28k+qd/oFG9SJckBsaX6DHp
Decrypted Text After Decryption: AES Symmetric Encryption Decryption
answered Mar 27 at 7:35
Hamidreza KalantariHamidreza Kalantari
4071 silver badge7 bronze badges
4071 silver badge7 bronze badges
Here I want to know what is the default mode which my java code is using and how to replicate the same in golang.
– Prashant Gupta
Mar 27 at 8:59
@PrashantGupta relying on default mode is risky. You should set it explicitly. As I said, you can use GCM in golang and java but if you don't want to use bouncy castle, you can use CBC mode in both languages.
– Hamidreza Kalantari
Mar 27 at 9:05
add a comment |
Here I want to know what is the default mode which my java code is using and how to replicate the same in golang.
– Prashant Gupta
Mar 27 at 8:59
@PrashantGupta relying on default mode is risky. You should set it explicitly. As I said, you can use GCM in golang and java but if you don't want to use bouncy castle, you can use CBC mode in both languages.
– Hamidreza Kalantari
Mar 27 at 9:05
Here I want to know what is the default mode which my java code is using and how to replicate the same in golang.
– Prashant Gupta
Mar 27 at 8:59
Here I want to know what is the default mode which my java code is using and how to replicate the same in golang.
– Prashant Gupta
Mar 27 at 8:59
@PrashantGupta relying on default mode is risky. You should set it explicitly. As I said, you can use GCM in golang and java but if you don't want to use bouncy castle, you can use CBC mode in both languages.
– Hamidreza Kalantari
Mar 27 at 9:05
@PrashantGupta relying on default mode is risky. You should set it explicitly. As I said, you can use GCM in golang and java but if you don't want to use bouncy castle, you can use CBC mode in both languages.
– Hamidreza Kalantari
Mar 27 at 9:05
add a comment |
Got a question that you can’t ask on public Stack Overflow? Learn more about sharing private information with Stack Overflow for Teams.
Got a question that you can’t ask on public Stack Overflow? Learn more about sharing private information with Stack Overflow for Teams.
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55370699%2fgetting-different-result-cyphertext-while-using-aes-in-java-and-golang%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Java's getBytes is not deterministic but depends on the default charset.
– Volker
Mar 27 at 6:13
AES use random initial vector for encryption. Every call generates random initial vector and this cause different encrypted text.
– Dogushan KAYA
Mar 27 at 7:18
@DogushanKAYA : The code which I pasted here, generating the same encrypted text.
– Prashant Gupta
Mar 27 at 8:57