CRC即循环冗余校验码(Cyclic Redundancy Check[1] ):是数据通信领域中最常用的一种查错校验码,其特征是信息字段和校验字段的长度可以任意选定。循环冗余检查(CRC)是一种数据传输检错功能,对数据进行多项式计算,并将得到的结果附在帧的后面,接收设备也执行类似的算法,以保证数据传输的正确性和完整性。
package sk.ann;
public class CRCCheck {
public static void main(String[] args){
String str="Java生成CRC16数据校验码";
byte[] data=str.getBytes();
System.out.println(CRCCheck.Make_CRC(data));
}
/**
* 计算产生校验码
* @param data 需要校验的数据
* @return 校验码
*/
public static String Make_CRC(byte[] data) {
byte[] buf = new byte[data.length];// 存储需要产生校验码的数据
for (int i = 0; i < data.length; i++) {
buf[i] = data[i];
}
int len = buf.length;
int crc = 0xFFFF;//16位
for (int pos = 0; pos < len; pos++) {
if (buf[pos] < 0) {
crc ^= (int) buf[pos] + 256; // XOR byte into least sig. byte of
// crc
} else {
crc ^= (int) buf[pos]; // XOR byte into least sig. byte of crc
}
for (int i = 8; i != 0; i--) { // Loop over each bit
if ((crc & 0x0001) != 0) { // If the LSB is set
crc >>= 1; // Shift right and XOR 0xA001
crc ^= 0xA001;
} else
// Else LSB is not set
crc >>= 1; // Just shift right
}
}
String c = Integer.toHexString(crc);
if (c.length() == 4) {
c = c.substring(2, 4) + c.substring(0, 2);
} else if (c.length() == 3) {
c = "0" + c;
c = c.substring(2, 4) + c.substring(0, 2);
} else if (c.length() == 2) {
c = "0" + c.substring(1, 2) + "0" + c.substring(0, 1);
}
return c;
}
}