CRC-16校验
首先附上一个校验网站 www.ip33.com/crc.html
XMODEM校验JAVA实现方法
首先是调用下面我封装的方法,具体传入字符串,一般是16进制的字符串较多
public static String GetCRC_XMODEM_Str(String str) {
byte[] bytes = HexStringToBytes(str);//16进制字符串转成16进制字符串数组
int i = CRC16_XMODEM(bytes);//进行CRC—XMODEM校验得到十进制校验数
String CRC = Integer.toHexString(i);//10进制转16进制
return CRC;
}
上面方法中有两个重要的方法,第一个是将传入的16进制字符串转成一个byte[],第二个方法是将转换的byte[]数组实现CRC16_XMODEM校验加密得到一个十进制的数字,此时只需将10进制转成16进制字符串就可以了,其具体实现的两个方法如下,也是静态可直接使用
//TODO 具体的实现CRC_XMODEM的方法
public static int CRC16_XMODEM(byte[] buffer) {
/* StringUtil.getByteArrayByString();*/
int wCRCin = 0x0000; // initial value 65535
int wCPoly = 0x1021; // 0001 0000 0010 0001 (0, 5, 12)
for (byte b : buffer) {
for (int i = 0; i < 8; i++) {
boolean bit = ((b >> (7 - i) & 1) == 1);
boolean c15 = ((wCRCin >> 15 & 1) == 1);
wCRCin <<= 1;
if (c15 ^ bit)
wCRCin ^= wCPoly;
}
}
wCRCin &= 0xffff;
return wCRCin ^= 0x0000;
}
//TODO 此静态方法是实现将16进制的字符串转成byte数组
public static byte[] HexStringToBytes(String src) {
int len = src.length() / 2;
byte[] ret = new byte[len];
byte[] tmp = src.getBytes();
for (int i = 0; i < len; i++) {
ret[i] = uniteBytes(tmp[i * 2], tmp[i * 2 + 1]);
}
return ret;
}