
net.java.truevfs.comp.zip.WinZipAesCipher Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of truevfs-comp-zip Show documentation
Show all versions of truevfs-comp-zip Show documentation
Provides basic functionality for reading and writing ZIP files.
/*
* Copyright (C) 2005-2015 Schlichtherle IT Services.
* All rights reserved. Use is subject to license terms.
*/
package net.java.truevfs.comp.zip;
import net.java.truevfs.comp.zip.crypto.CtrBlockCipher;
import org.bouncycastle.crypto.engines.AESFastEngine;
/**
* Implements Counter (CTR) mode (alias Segmented Integer Counter - SIC)
* on top of an AES engine.
* This class is almost identical to {@link CtrBlockCipher} except that
* the block counter is incremented before updating the cipher input
* in little endian order.
*
* @see A Password Based File Encyption Utility (Dr. Gladman)
* @author Christian Schlichtherle
*/
final class WinZipAesCipher extends CtrBlockCipher {
/**
* Constructs a new block cipher mode for use with WinZip AES.
* This constructor uses an {@link AESFastEngine} as the underlying block
* cipher.
*/
WinZipAesCipher() {
super(new AESFastEngine());
}
@Override
protected void incCounter() {
final int blockSize = this.blockSize;
long blockCounter = ++this.blockCounter; // pre-increment the block counter!
for (int i = 0; i < blockSize; i++) { // little endian order!
blockCounter += IV[i] & 0xff;
cipherIn[i] = (byte) blockCounter;
blockCounter >>>= 8;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy