CRC16算法系列文章:
前言
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);
- }
- }