java - 在 Android 中加密和解密文件的任何优化方式

标签 java android file

这是我当前用于加密和解密过程的代码,它的工作原理应该是这样,除了加密和解密的时间太长了。

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import javax.crypto.Cipher;
import javax.crypto.CipherInputStream;
import javax.crypto.CipherOutputStream;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;

public class EncryptAndDecrypt{

   public static void main(String[] args) {
    try {
        String key = "myencryptedpass123";

        FileInputStream fis = new FileInputStream("File_to_encrypt.mp4");
        FileOutputStream fos = new FileOutputStream("Encrypted_file.mp4");
        encrypt(key, fis, fos);

        FileInputStream fis2 = new FileInputStream("Encrypted_file.mp4");
        FileOutputStream fos2 = new FileOutputStream("File_to_decrypt.mp4");
        decrypt(key, fis2, fos2);
    } catch (Throwable e) {
        e.printStackTrace();
    }
}

public static void encrypt(String key, InputStream is, OutputStream os) throws Throwable {
    encryptOrDecrypt(key, Cipher.ENCRYPT_MODE, is, os);
}

public static void decrypt(String key, InputStream is, OutputStream os) throws Throwable {
    encryptOrDecrypt(key, Cipher.DECRYPT_MODE, is, os);
}

public static void encryptOrDecrypt(String key, int mode, InputStream is, OutputStream os) throws Throwable {

    DESKeySpec dks = new DESKeySpec(key.getBytes());
    SecretKeyFactory skf = SecretKeyFactory.getInstance("DES");
    SecretKey desKey = skf.generateSecret(dks);
    Cipher cipher = Cipher.getInstance("DES"); 

    if (mode == Cipher.ENCRYPT_MODE) {
        cipher.init(Cipher.ENCRYPT_MODE, desKey);
        CipherInputStream cis = new CipherInputStream(is, cipher);
        doCopy(cis, os);
    } else if (mode == Cipher.DECRYPT_MODE) {
        cipher.init(Cipher.DECRYPT_MODE, desKey);
        CipherOutputStream cos = new CipherOutputStream(os, cipher);
        doCopy(is, cos);
    }
}

public static void doCopy(InputStream is, OutputStream os) throws IOException {
    byte[] bytes = new byte[64];
    int numBytes;
    while ((numBytes = is.read(bytes)) != -1) {
        os.write(bytes, 0, numBytes);
    }
    os.flush();
    os.close();
    is.close();
}

现在我希望有更好的解决方案...

最佳答案

肯定会使用更大的缓冲区,但加密主要受 CPU 限制,因此不太可能变得更快。另外

  • 如果您“不担心安全漏洞”,最好完全放弃加密
  • 您正在使用 DES,请不要
  • 您正在使用人类可读的字符串作为键——不要
  • 一旦您使用单独的 Cipher 实例进行加密和解密,该代码可能无法工作
  • 如果您使用默认设置,您就是在给自己惹麻烦。使用像 Cipher.getInstance("AES/CBC/PKCS5Padding")
  • 这样的东西
  • 如果你想让它在 Android 上运行,为什么要在桌面上进行测试?

是的,如果您将 key 包含在应用程序中,您的“DRM”就没有多大用处。

关于java - 在 Android 中加密和解密文件的任何优化方式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10535714/

相关文章:

java - 如何在java中获取数据库的表结构?

java - 当我尝试通过拖放运行 Android 应用程序时出现意外错误

c# - MemoryStream 没有向文件写入任何内容

java - 使用 lambda 在函数中传递两个参数

java - 什么是 | Java 中的运算符在做什么?

java - Java 类中的 RealMatrix 对象

android - 如何实现双击 ImageView onclick?

android - JsonWriter 写入 GSON 文件时出现嵌套错误

c - 在 Ubuntu 的终端中查找文件及其在目录中的路径,argv [2] 中给出的文件名

file - Erlang mime 类型