android解除加密文件,解密加密文件会破坏文件? Android的 - Java的

import javax.crypto.BadPaddingException;

import javax.crypto.Cipher;

import javax.crypto.IllegalBlockSizeException;

import javax.crypto.NoSuchPaddingException;

import javax.crypto.spec.SecretKeySpec;

public class CryptoUtils {

private static final String ALGORITHM = "AES";

private static final String TRANSFORMATION = "AES";

public static void encrypt(String key, File inputFile, File outputFile)

throws CryptoException {

doCrypto(Cipher.ENCRYPT_MODE, key, inputFile, outputFile);

}

public static void decrypt(String key, File inputFile, File outputFile)

throws CryptoException {

doCrypto(Cipher.DECRYPT_MODE, key, inputFile, outputFile);

}

private static void doCrypto(int cipherMode, String key, File inputFile,

File outputFile) throws CryptoException {

try {

Key secretKey = new SecretKeySpec(key.getBytes(), ALGORITHM);

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PAdding");

cipher.init(cipherMode, secretKey);

FileInputStream inputStream = new FileInputStream(inputFile);

byte[] inputBytes = new byte[(int) inputFile.length()];

inputStream.read(inputBytes);

byte[] outputBytes = cipher.doFinal(inputBytes);

FileOutputStream outputStream = new FileOutputStream(outputFile);

outputStream.write(outputBytes);

inputStream.close();

outputStream.close();

} catch (NoSuchPaddingException e) {

e.printStackTrace();

} catch (NoSuchAlgorithmException

| InvalidKeyException | BadPaddingException

| IllegalBlockSizeException | IOException ex) {

throw new CryptoException("Error encrypting/decrypting file", ex);

}

}

public static class CryptoException extends Exception {

public CryptoException() {

}

public CryptoException(String message, Throwable throwable) {

super(message, throwable);

}

}

}

我可以加密和解密的视频文件。 但是,我无法播放由相同代码加密的解密文件。

的前16个字节解密文件的是从原始文件不同。长度是一样的。

+1

我对Java中的加密技术不太感兴趣,特别是在Android下,但我担心我没有看到如何将您的IV从加密函数传递给解密函数。 CBC模式使用该初始化向量来混淆第一个加密输出块,因此即使使用相同的密钥,相同的纯文本也会产生完全不同的加密文本。如果您使用与您在加密时使用的不同的IV进行解密,则解密将成功,但第一个块(16个字节)将被加密。尝试明确提供您的IV(硬编码测试,如果你喜欢),看看是否有效。 –

+1

我没有提到我的怀疑,但在C#中.NET,如果你有CBC模式,并没有指定你的IV,算法会随机产生一个。通常,您会将其作为加密输出的第一个块编写,然后将其作为第一个加密输入块进行读取,以便使用该算法来准备解密算法。因此,将随机IV写入输出文件的开头,或者(仅用于测试)将其硬编码到程序中。请注意,硬编码的IV失去了IV提供的所有有益特性。但出于测试目的,我会尝试。 –

+0

不知道你如何加密它,这是不可能知道解密代码有什么问题。我不想玩[猜谜游戏](https://blog.stackoverflow.com/2012/02/lets-play-the-guessing-game/)。 –

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值