为什么80%的码农都做不了架构师?>>>   

CRC校验网站: https://www.lammertbies.nl/comm/info/crc-calculation.html

一、CRC-CCITT(0xFFFF) 校验代码:

public class CRCTest {/*** CRC-CCITT (0xFFFF)* * @param bytes* @return*/public static int getCRC(byte[] bytes) {int crc = 0xFFFF;int polynomial = 0x1021;for (byte b : bytes) {for (int i = 0; i < 8; i++) {boolean bit = ((b >> (7 - i) & 1) == 1);boolean c15 = ((crc >> 15 & 1) == 1);crc <<= 1;if (c15 ^ bit) {crc ^= polynomial;}}}crc &= 0xFFFF;return crc;}public static void main(String[] args) {byte[] test = StringUtils.decodeHex("00000048000053261001000003E90100000000000000000003E94C");int abc = getCRC(test);System.out.println(Integer.toHexString(abc).toUpperCase());}}

代码中StringUtils 类是本地工具类;

二、modbusCRC 校验代码

public class ModbusCRCUtil {public int value; public ModbusCRCUtil() {   value = 0;   } static final String HEXES = "0123456789ABCDEF";byte uchCRCHi = (byte) 0xFF;  byte uchCRCLo = (byte) 0xFF;  /**  CRC 高位字节值表 */private static  char auchCRCHi[] = {0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41,0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,0x80, 0x41, 0x00, 0xC1, 0x81, 0x40};/* * CRC低位字节值表* */private static char auchCRCLo[] = {0x00, 0xC0, 0xC1, 0x01, 0xC3, 0x03, 0x02, 0xC2, 0xC6, 0x06,0x07, 0xC7, 0x05, 0xC5, 0xC4, 0x04, 0xCC, 0x0C, 0x0D, 0xCD,0x0F, 0xCF, 0xCE, 0x0E, 0x0A, 0xCA, 0xCB, 0x0B, 0xC9, 0x09,0x08, 0xC8, 0xD8, 0x18, 0x19, 0xD9, 0x1B, 0xDB, 0xDA, 0x1A,0x1E, 0xDE, 0xDF, 0x1F, 0xDD, 0x1D, 0x1C, 0xDC, 0x14, 0xD4,0xD5, 0x15, 0xD7, 0x17, 0x16, 0xD6, 0xD2, 0x12, 0x13, 0xD3,0x11, 0xD1, 0xD0, 0x10, 0xF0, 0x30, 0x31, 0xF1, 0x33, 0xF3,0xF2, 0x32, 0x36, 0xF6, 0xF7, 0x37, 0xF5, 0x35, 0x34, 0xF4,0x3C, 0xFC, 0xFD, 0x3D, 0xFF, 0x3F, 0x3E, 0xFE, 0xFA, 0x3A,0x3B, 0xFB, 0x39, 0xF9, 0xF8, 0x38, 0x28, 0xE8, 0xE9, 0x29,0xEB, 0x2B, 0x2A, 0xEA, 0xEE, 0x2E, 0x2F, 0xEF, 0x2D, 0xED,0xEC, 0x2C, 0xE4, 0x24, 0x25, 0xE5, 0x27, 0xE7, 0xE6, 0x26,0x22, 0xE2, 0xE3, 0x23, 0xE1, 0x21, 0x20, 0xE0, 0xA0, 0x60,0x61, 0xA1, 0x63, 0xA3, 0xA2, 0x62, 0x66, 0xA6, 0xA7, 0x67,0xA5, 0x65, 0x64, 0xA4, 0x6C, 0xAC, 0xAD, 0x6D, 0xAF, 0x6F,0x6E, 0xAE, 0xAA, 0x6A, 0x6B, 0xAB, 0x69, 0xA9, 0xA8, 0x68,0x78, 0xB8, 0xB9, 0x79, 0xBB, 0x7B, 0x7A, 0xBA, 0xBE, 0x7E,0x7F, 0xBF, 0x7D, 0xBD, 0xBC, 0x7C, 0xB4, 0x74, 0x75, 0xB5,0x77, 0xB7, 0xB6, 0x76, 0x72, 0xB2, 0xB3, 0x73, 0xB1, 0x71,0x70, 0xB0, 0x50, 0x90, 0x91, 0x51, 0x93, 0x53, 0x52, 0x92,0x96, 0x56, 0x57, 0x97, 0x55, 0x95, 0x94, 0x54, 0x9C, 0x5C,0x5D, 0x9D, 0x5F, 0x9F, 0x9E, 0x5E, 0x5A, 0x9A, 0x9B, 0x5B,0x99, 0x59, 0x58, 0x98, 0x88, 0x48, 0x49, 0x89, 0x4B, 0x8B,0x8A, 0x4A, 0x4E, 0x8E, 0x8F, 0x4F, 0x8D, 0x4D, 0x4C, 0x8C,0x44, 0x84, 0x85, 0x45, 0x87, 0x47, 0x46, 0x86, 0x82, 0x42,0x43, 0x83, 0x41, 0x81, 0x80, 0x40};public void update(byte[] puchMsg, int usDataLen) {    int uIndex; for (int i = 0; i < usDataLen; i++) {    uIndex = (uchCRCHi ^ puchMsg[i]) & 0xff; uchCRCHi = (byte) (uchCRCLo ^ auchCRCHi[uIndex]);    uchCRCLo = (byte)auchCRCLo[uIndex]; } value = ((((int) uchCRCHi) << 8 | (((int) uchCRCLo) & 0xFF))) & 0xFFFF; return; } public void reset() {value = 0;   uchCRCHi = (byte) 0xFF;   uchCRCLo = (byte) 0xFF;  } public int getValue() {  return value;  } public static byte[] getCRCBuf(byte[] bb){ModbusCRCUtil crc16 = new ModbusCRCUtil(); crc16.update(bb, bb.length); int ri = crc16.getValue();  byte crcHi = (byte) (0xff & ri);byte crcLo = (byte) ((0xff00 & ri) >> 8);return new byte[]{ crcLo,crcHi };  }      }

转载于:https://my.oschina.net/gmd/blog/1541816

modbusCRC 、CRC-CCITT(0xFFFF) 校验相关推荐

  1. bcc校验位怎么算的_BCC(异或校验)、CRC、LRC校验算法

    一.校验算法 BCC(Block Check Character/信息组校验码),好像也是常说的异或校验方法 CRC(Cyclic Redundancy Check/循环冗余校验) LRC(Longi ...

  2. 文件CRC和MD5校验

    文件CRC和MD5校验 CRC和MD5用于文件和数据的传输校验,以确认是否接收成功. unit CRCMD5;interface { 获取文件CRC校验码 } function GetFileCRC( ...

  3. 【算法】CRC 循环冗余校验

    1.概述 循环冗余校验CRC (Cyclic Redundancy Check)是一种数据链路层的差错控制技术. 在数据的传输过程中可能会产生比特错误: 1可能变为0,0可能变为1. 在一段时间内,传 ...

  4. 协议crc计算_CRC校验原理及代码实现(一)

    网上的有关CRC的原理和代码实现的文章,数不胜数,但比较全的好像还没看到:此文是集百家之智慧,加之自己的使用经验和理解汇聚此文,让你快速理解和使用CRC,当然不足之处欢迎评论区吐槽. 1. CRC是什 ...

  5. 从原理到代码理解CRC循环冗余校验

    概述:本文详细介绍了CRC循环冗余计算的数学原理,算法中使用的参数说明,并以Modbus协议中的CRC-16算法为例,进行手算验证,同时提供LabVIEW和C语言的直接计算CRC-16 值的代码以及C ...

  6. CRC 计算及校验原理

    第一步 给定要发送的数据码 原数据码 =10110011 第二步 根据给定的生成多项式,确定除数码, 除数码 = 11001 第三步 根据生成多项式的最高阶次幂(此处为4),在数据码后补 4个0 新数 ...

  7. MODBUS-RTU和ASCII模式及CRC和LRC校验方法简述

    MODBUS简述 Modbus是一种串行通信协议,是Modicon公司(现在的施耐德电气Schneider Electric)于1979年为使用可编程逻辑控制器(PLC)通信而发表.Modbus已经成 ...

  8. 在Python中使用CRC进行数据校验

    原文出处: https://xugaoxiang.com/2019/12/08/python-crc/ 软硬件环境 ubuntu 18.04 64bit anaconda with python 3. ...

  9. crc循环冗余校验 php,crc 循环冗余校验

    --- title: crc 循环冗余校验 date: 2018-09-26 updated: 2018-10-06 --- # crc 循环冗余校验 CRC(Cyclic Redundancy Ch ...

最新文章

  1. Oracl 12c (课本)
  2. BFS之三(单向bfs和康托压缩)
  3. 简单介绍python迭代器和生成器
  4. Nginx配置和内核优化 实现突破十万并发
  5. python3入门书籍-零基础自学python3 好用的入门书籍推荐
  6. 程序员到底需要什么样的需求文档?
  7. 第一百七十四节,jQuery,Ajax进阶
  8. 18岁初中毕业学Java_刚满十八 初中毕业 java自学完了 没学历 该怎么办?
  9. 海报psd素材模板|周年海报,仪式感值得珍藏
  10. BZOJ4372: 烁烁的游戏【动态点分治】
  11. 事件绑定,事件捕获,事件冒泡以及事件委托,兼容IE
  12. 吴恩达机器学习作业一
  13. sql 主键 外键
  14. 计算机专业课程设计收获及总结,课程设计的心得体会
  15. 【NLP】Pre-train,Prompt,and Predict
  16. 点云3d检测SA-SSD
  17. flutter 项目实践2
  18. ssh远程连接ubuntu后UI在本地显示
  19. android移动应用开发 基于adobe air 下载,基于Adobe AIR的下一代移动应用开发
  20. 5.准确量出2升水,如果你有4升和5升的碗

热门文章

  1. html页面证书过期,网页上的完全证书过期过失效怎么处理
  2. 用 Python 写了个 PDF 转换器,免费转换格式~
  3. java 视频 解码_关于视频解码总结--JavaCV
  4. C——Linux下的串口编程
  5. C# Console Application 带参数调试
  6. 【转】很全的英语短语
  7. 从零开始学CIRCOS绘制圈图(二)
  8. HIVE学习系列——windows Hadoop安装(下)
  9. Android V1签名与校验原理分析(全网最全最详细)
  10. 防止APP被黑客攻击的解决方案