CRC-16/XMODEM校验Java实现方法
CRC-16的加密校验方法有很多,现在分享一下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;
}
以上的CRC16校验只是针对XMODEM这种,其他校验不能验证,所以在使用的时候,需要分析清楚自己用的是那种类型的校验方式