:
前言
JDK里包含了CRC32的算法,但是没有CRC16的,网上搜了一堆没有找到想要的,索性自己实现
注意:CRC16算法分为很多种,本篇文章中,只讲其中的一种:CRC16-CCITT-FALSE算法
CRC16算法系列之一:CRC16-CCITT-FALSE算法的java实现
功能
1、支持short类型
2、支持int类型
3、支持数组任意区域计算
实现
/**
* crc16-ccitt-false加密工具
*
* @author eguid
*
*/
public class CRC16 {
/**
* crc16-ccitt-false加/解密(四字节)
*
* @param bytes
* @return
*/
public static int crc16(byte[] bytes) {
return crc16(bytes, bytes.length);
}
/**
* crc16-ccitt-false加/解密(四字节)
*
* @param bytes -字节数组
* @return
*/
public static int crc16(byte[] bytes, int len) {
int crc = 0xFFFF;
for (int j = 0; j < len; j++) {
crc = ((crc >>> 8) | (crc << 8)) & 0xffff;
crc ^= (bytes[j] & 0xff);// byte to int, trunc sign
crc ^= ((crc & 0xff) >> 4);
crc ^= (crc << 12) & 0xffff;
crc ^= ((crc & 0xFF) << 5) & 0xffff;
}
crc &= 0xffff;
return crc;
}
/**
* crc16-ccitt-false加/解密(四字节)
*
* @param bytes
* @return
*/
public static int crc16(byte[] bytes, int start, int len) {
int crc = 0xFFFF;
for (; start < len; start++) {
crc = ((crc >>> 8) | (crc << 8)) & 0xffff;
crc ^= (bytes[start] & 0xff);// byte to int, trunc sign
crc ^= ((crc & 0xff) >> 4);
crc ^= (crc << 12) & 0xffff;
crc ^= ((crc & 0xFF) << 5) & 0xffff;
}
crc &= 0xffff;
return crc;
}
/**
* crc16-ccitt-false加/解密
*
* @param bytes
* -字节数组
* @return
*/
public static short crc16_short(byte[] bytes) {
return crc16_short(bytes, 0, bytes.length);
}
/**
* crc16-ccitt-false加/解密(计算从0位置开始的len长度)
*
* @param bytes
* -字节数组
* @param len
* -长度
* @return
*/
public static short crc16_short(byte[] bytes, int len) {
return (short) crc16(bytes, len);
}
/**
* crc16-ccitt-false加/解密(两字节)
*
* @param bytes
* @return
*/
public static short crc16_short(byte[] bytes, int start, int len) {
return (short) crc16(bytes, start, len);
}
}