Active Topics

 


Reply
Thread Tools
Posts: 9 | Thanked: 0 times | Joined on Apr 2009
#1
I compiled an AES program on eclipse java in my laptop and everything was OK

This is the programm

import java.security.*;
import javax.crypto.*;
import javax.crypto.spec.*;
import java.io.*;

/**
* This program generates a AES key, retrieves its raw bytes, and
* then reinstantiates a AES key from the key bytes.
* The reinstantiated key is used to initialize a AES cipher for
* encryption and decryption.
*/

public class AES {

/**
* Turns array of bytes into string
*
* @param buf Array of bytes to convert to hex string
* @return Generated hex string
*/
public static String asHex (byte buf[]) {
StringBuffer strbuf = new StringBuffer(buf.length * 2);
int i;

for (i = 0; i < buf.length; i++) {
if (((int) buf[i] & 0xff) < 0x10)
strbuf.append("0");

strbuf.append(Long.toString((int) buf[i] & 0xff, 16));
}

return strbuf.toString();
}

public static void main(String[] args) throws Exception {

String message="This is just an example";

// Get the KeyGenerator

KeyGenerator kgen = KeyGenerator.getInstance("AES");
kgen.init(128); // 192 and 256 bits may not be available


// Generate the secret key specs.
SecretKey skey = kgen.generateKey();
byte[] raw = skey.getEncoded();

SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");


// Instantiate the cipher

Cipher cipher = Cipher.getInstance("AES");

cipher.init(Cipher.ENCRYPT_MODE, skeySpec);

byte[] encrypted =
cipher.doFinal((args.length == 0 ?
"This is just an example" : args[0]).getBytes());
System.out.println("encrypted string: " + asHex(encrypted));

cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] original =
cipher.doFinal(encrypted);
String originalString = new String(original);
System.out.println("Original string: " +
originalString + " " + asHex(original));
}
}


, but when i tried to do the same thing on the n81o device this is the error which i got :


Exception in thread "main" javax.crypto.IllegalBlockSizeException: 7 trailing bytes
at gnu.javax.crypto.jce.cipher.CipherAdapter.engineDo Final(CipherAdapter.java:491)
at javax.crypto.Cipher.doFinal(Cipher.java:495)
at javax.crypto.Cipher.doFinal(Cipher.java:461)
at org.test2.AES.main(AES.java:62)


can some one explain to me this error and how could i resolve it

PS: I tried the hash function sha1 on the device and it works very well.
 
Reply


 
Forum Jump


All times are GMT. The time now is 17:07.