草庐IT

java - 在java中使用AES有效加密文件

我正在开发一个应该加密一些小文件(小于1MB)和大文件(大约500MB)的应用程序。如何加密文件并将加密版本有效地保存在磁盘上的某个位置(即快速)?如果花时间我可以有加密进度吗? 最佳答案 假设您有一个AESkey和一些输出流,下面介绍了如何向流中添加加密装饰器。Cipherenc=Cipher.getInstance("AES/CBC/PKCS5Padding");enc.init(Cipher.ENCRYPT_MODE,key);AlgorithmParametersparams=enc.getParameters();IvPa

java - 这种 AES 加密是否足够安全?

我从http://www.ravenblast.com/index.php/blog/android-password-text-encryption/得到了这段代码而且,虽然它有效,但我越来越怀疑它不够安全。根据其他来源,似乎没有任何必要的初始化vector。publicstaticStringencrypt(StringtoEncrypt,byte[]key)throwsException{SecretKeySpecskeySpec=newSecretKeySpec(key,"AES");Ciphercipher=Cipher.getInstance("AES");cipher.i

java - 调试 AES-CMAC,生成错误答案

我正在使用以下代码和类从AES_CMAC生成多样化key。doFinal方法每次返回不同的key,因为输入和masterKey是常量。publicbyte[]calculateDiverseKey(byte[]input)throwsInvalidKeyException,NoSuchAlgorithmException{AesCmacmac=null;mac=newAesCmac();SecretKeykey=newSecretKeySpec(masterKey,"AES");mac.init(key);//setmasterkeymac.updateBlock(input);//g

Python学习笔记——AES 加密/解密

前言:AES,高级加密标准。目前比较流行的对称加密算法。是一种对称加密算法,即加密和解密都用相同的密钥。AES只是个基本算法,实现AES有几种模式,主要有ECB、CBC、CFB等几种模式。CBC模式中还有一个偏移量参数IV。AES加密有AES-128、AES-192和AES-256三种,分别对应三种密钥长度128位(16字节)、192位(24字节)和256位(32字节)。密钥越长,安全性越高,加密和解密时间也会更长。一般默认是128位,其安全性完全够用。一、加密/解密时,字节数不够时的处理:加密时:因为密钥是16字节,所以明文加密时,字符串不足16字节的倍数,则要补充个数,例如:少4个,要补c

java - 为什么 AtomicReference CAS 返回值为 128 的 false?

我使用AtomicReference来实现AtomicInteger。然而,在测试中,我注意到即使在单线程环境中,一旦CAS操作的值达到128,CAS操作就会卡住。我是做错了什么还是AtomicReference中有警告(可能与CPU相关)?这是我的代码:publicclassMyAtomInt{privatefinalAtomicReferenceref;publicMyAtomInt(intinit){ref=newAtomicReference(init);}publicMyAtomInt(){this(0);}publicvoidinc(){while(true){intold

java - PKCS5Padding 可以使用 AES/GCM 模式吗?

AES/GCM的填充模式是什么?我知道它可以是NoPadding,因为在ECB模式下它可以是PKCS5Padding,在GCM模式下怎么样?在JCE接口(interface)中,我们需要提供“算法/模式/填充”(Reference)。所以我使用下面的代码来获取实例,它在JDK中工作,但在IBMSDK中失败,它说cannotfindproviderforsupportingAES/GCM/PKCS5PaddingCipher.getInstance("AES/GCM/PKCS5Padding");填充的实际用例是什么? 最佳答案 GC

java - Cipher.getInstance() 和 Cipher.getInit() 用于 AES 加密的随机 IV 情况下的每条消息

在多线程Java应用程序中,我们使用AES-256对磁盘文件进行加密和解密。请注意,多个线程可以同时调用不同文件的加密和解密方法。加密:Cipherencrypter=Cipher.getInstance(algorithm,newBouncyCastleProvider());IvParameterSpecivSpec=getIvParamSpec(encrypter.getBlockSize());encrypter.init(Cipher.ENCRYPT_MODE,key,ivSpec);//..encryptthedata解密:Cipherdecrypter=Cipher.ge

java 128位结构位操作

有没有一种方法可以在java中创建一个128位对象,可以像long或int一样进行位操作?我想做32位移位,我希望能够对整个128位结构进行位或运算。 最佳答案 在这里,我向您介绍...一个古老的想法。现在它被严重降级(没有代码增强器,什么都没有)到应该超快的简单128位东西。我真正想要的是一个基于ByteBuffer的C数组,类似于Struct,但完全可以在Java中使用。主要思想是一次分配多个对象并使用指向数组的指针。因此,它大大节省了内存,并且内存分配在连续区域,因此缓存未命中率较低(总是很好)。我做了一些适度的测试(但代码仍

java - 为什么这个 AES 加密程序在每次调用时给出不同的值?

基本上我找到了这个代码,由某人发布,它允许您在AES中加密消息并解密它。我对这个加密东西有点陌生,我想知道,它使用的种子值在哪里,种子每次都是随机的吗?因为从表面上看,同一个String加密后的结果是不一样的。谢谢。importjava.awt.event.*;importjava.awt.*;importjavax.swing.*;importjava.security.*;importjavax.crypto.*;importjavax.crypto.spec.*;importjava.io.*;publicclassAESGUIextendsJPanel{publicstatic

java - 遍历所有字节值 -128-127 而无需在 Java 中强制转换

我需要遍历所有字节值(-128到127,包括在内)。我可以使用int迭代器,但我每次都必须转换为byte.使用byte迭代器有我无法测试b的问题因为它会溢出。我想到了使用while循环并在递增之前进行测试,这是迄今为止我最好的解决方案。有没有更好的方法? 最佳答案 Java字节是有符号的,所以它们的值是-128到127。无论如何,你不应该担心类型转换和额外的检查,因为它们很容易优化掉。事实上,在JVM级别,没有字节变量这样的东西。无论如何,它都被视为一个int。 关于java-遍历所有字