我正在使用PHP加密数据,而不是在解密我的Android应用程序中的数据(图像),但有时它会让我产生IOException并且我不确定如何修复它。当我在加密一个PNG图像文件,没关系,没有异常抛出,我的应用程序可以在列表视图中加载图像。但是当我加密一个jpg文件时,它正在抛出这个异常:
08-04 06:36:54.734: WARN/System.err(254): java.io.IOException: data not block size aligned
08-04 06:36:54.734: WARN/System.err(254): at javax.crypto.CipherInputStream.read(CipherInputStream.java:97)
08-04 06:36:54.734: WARN/System.err(254): at javax.crypto.CipherInputStream.read(CipherInputStream.java:152)
08-04 06:36:54.734: WARN/System.err(254): at java.io.BufferedInputStream.fillbuf(BufferedInputStream.java:183)
08-04 06:36:54.734: WARN/System.err(254): at java.io.BufferedInputStream.read(BufferedInputStream.java:346)
08-04 06:36:54.734: WARN/System.err(254): at android.graphics.BitmapFactory.nativeDecodeStream(Native Method)
08-04 06:36:54.734: WARN/System.err(254): at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:459)
08-04 06:36:54.734: WARN/System.err(254): at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:515)
08-04 06:36:54.734: WARN/System.err(254): at com.custom.lazylist.ImageLoader.getBitmap(ImageLoader.java:105)
08-04 06:36:54.734: WARN/System.err(254): at com.custom.lazylist.ImageLoader.access$0(ImageLoader.java:75)
08-04 06:36:54.734: WARN/System.err(254): at com.custom.lazylist.ImageLoader$PhotosLoader.run(ImageLoader.java:228)
我在网上看到,问题可能是在加密和解密代码时使用NoPadding。这是Java代码和PHP代码:
JAVA
try {
Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");
SecretKeySpec keySpec = new SecretKeySpec("01234567890abcde".getBytes(), "AES");
IvParameterSpec ivSpec = new IvParameterSpec("fedcba9876543210".getBytes());
cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec);
AssetManager is = this.getAssets();
InputStream fis = is.open("card2_encrypted.jpg");
CipherInputStream cis = new CipherInputStream(fis, cipher);
FileOutputStream fos = new FileOutputStream(
new File(Environment.getExternalStorageDirectory(), "card2_decrypted.jpg"));
byte[] b = new byte[8];
int i;
while ((i = cis.read(b)) != -1) {
fos.write(b, 0, i);
}
fos.flush(); fos.close();
cis.close(); fis.close();
}
catch(Exception e){
e.fillInStackTrace();
Log.v("Error","Error "+e);
}
}
和 PHP 代码:
<?php
$secret_key = "01234567890abcde";
$iv = "fedcba9876543210";
$infile = "ss1.jpg";
$outfile = "ss1_encrypted.jpg";
$crypttext = file_get_contents($infile);
$plaintext = mcrypt_encrypt(MCRYPT_RIJNDAEL_128,
$secret_key, $crypttext, MCRYPT_MODE_CBC, $iv);
header('Content-Type: application/octet-stream');
header('Content-Length: ' . strlen($plaintext));
header('Content-Disposition: attachment; filename=' . ($outfile));
echo $plaintext;
?>
所以我的问题是如何在php和java代码中使用填充来修复那些东西,所以我可以在我的应用程序中加载我的图像。谢谢你的帮助!
答案 0 :(得分:2)
您需要在加密端指定填充,并在解密端指定相同的填充,以便可以删除填充。您正在使用块密码AES,因此需要将所有消息填充到块大小的多个部分。因此,您的错误消息“数据不是块大小对齐”。
检查两端可用的填充,并选择他们都支持的填充。 PKCS#5是一种常见的填充约定,可能在两个系统上都可用。我不懂PHP,但在Java中你需要:
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");