
这是当前用于加密和解密过程的代码,它的工作方式也是如此,除了加密和解密的时间很长.
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内部文件的任何优化方式所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)