XTEA加密的一种JAVA实现,64轮,CBC模式,0填充

本文介绍了使用JAVA实现的XTEA加密算法,包括64轮加密过程和CBC模式的应用。提供了调用示例及加密结果的输出展示,并引用了相关资料,如XTEA的数据流图、C语言实现和加密模式的Wikipedia介绍,以及JAVA的32轮实现链接。
摘要由CSDN通过智能技术生成


XTEA加密的一种JAVA实现,64轮,CBC模式,0填充



/**
 * An implementation of the XTEA block cipher algorithm. 64 rounds, mode CBC, zero padding.
 * by zahuopuboss
 */
public class XTEA {
	private static final int BLOCK_ALIGN = 8;
	private static final int KEY_LENGTH = 16;
	private static final int DELTA = 0x9E3779B9;
	private static final int NUM_ROUNDS = 64;
	private int[] keys = new int[NUM_ROUNDS];
	private byte[] ivtmp = new byte[BLOCK_ALIGN];

	private void setKey(byte[] b) {
		int[] key = new int[4];
		for (int i = 0; i < KEY_LENGTH;) {
			key[i / 4] = (b[i++] << 24) + ((b[i++] & 255) << 16) + ((b[i++] & 255) << 8) + (b[i++] & 255);
		}
		for (int i = 0, sum = 0; i < NUM_ROUNDS;) {
			keys[i++] = sum + key[sum & 3];
			sum += DELTA;
			keys[i++] = sum + key[(sum >>> 11) & 3];
		}
	}

	private void setIV(byte[] b) {
		System.arraycopy(b, 0, ivtmp, 0, BLOCK_ALIGN);
	}

	private byte[] padding(byte[] in, int len) {
		int lennew = len;
		int mod = len % BLOCK_ALIGN;
		if (mod != 0) {
			lennew = ((len + BLOCK_ALIGN) / BLOCK_ALIGN) * BLOCK_ALIGN;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值