java– 加密和解密Android内部文件的任何优化方式

java– 加密和解密Android内部文件的任何优化方式,第1张

概述这是当前用于加密和解密过程的代码,它的工作方式也是如此,除了加密和解密的时间很长.importjava.io.FileInputStream;importjava.io.FileOutputStream;importjava.io.IOException;importjava.io.InputStream;importjava.io.OutputStream;importjavax.crypto.Cipher;i

这是当前用于加密和解密过程的代码,它的工作方式也是如此,除了加密和解密的时间很长.

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上运行,为什么要在桌面上进行测试?

是的,如果您在应用程序中包含密钥,那么您的“DRM”就没有多大用处.

总结

以上是内存溢出为你收集整理的java – 加密和解密Android内部文件的任何优化方式全部内容,希望文章能够帮你解决java – 加密和解密Android内部文件的任何优化方式所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1117687.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-29
下一篇2022-05-29

发表评论

登录后才能评论

评论列表(0条)

    保存