JS CRC16/XMODEM

const byteData= HexString2Bytes("1A3B4C5D")
let crc = crc16(byteData)
// CRC转换: A185
console.log("CRC转换:",crc)

function crc16(buffer) {
  var crc = 0x0000;
  var odd;

  for(var i = 0; i < buffer.length; i++) {
    crc ^= (buffer[i] << 8)
    for(var j = 0; j < 8; j++) {
      odd = crc & 0x8000;
      crc = crc << 1;
      if(odd) {
        crc = crc ^ 0x1021
      }
    }
  }

  var hi = ((crc & 0xFF00) >> 8); //高位置
  var lo = (crc & 0x00FF); //低位置
  var crcArr = []
  crcArr.push(hi)
  crcArr.push(lo)
  crc &= 0xFFFF
  return crcToString(crcArr, true)
};    

//转为大写String
function crcToString(arr, isReverse) {

  if(typeof isReverse == 'undefined') {
    isReverse = true;
  }

  var hi = arr[0],
  lo = arr[1];
  return padLeft((isReverse ? hi + lo * 0x100 : hi * 0x100 + lo).toString(16).toUpperCase(), 4, '0');

};

function padLeft(s, w, pc) {

    if (pc == undefined) {
        pc = '0';
    }

    for (var i = 0, c = w - s.length; i < c; i++) {
        s = pc + s;
    }

    return s;

};

//十六进制字符串转字节数组
function HexString2Bytes(str) {

    var pos = 0;
    var len = str.length;

    if (len % 2 != 0) {
      return null;
    }

    len /= 2;
    var arrBytes = new Array();

    for (var i = 0; i < len; i++) {
      var s = str.substr(pos, 2);
      var v = parseInt(s, 16);
      arrBytes.push(v);
      pos += 2;

    }

    return arrBytes;
  }
相关推荐
无限大.1 小时前
前端知识速记--HTML篇:src和href
前端·html
子非鱼9212 小时前
两栏布局、三栏布局、水平垂直居中
前端·javascript·css
程序猿小D2 小时前
第三百五十八节 JavaFX教程 - JavaFX滑块
java·前端·数据库
GISer_Jing3 小时前
React中useState()钩子和函数式组件底层渲染流程详解
前端·react.js·前端框架
行路见知3 小时前
1.5 Go切片使用
开发语言·golang
私人珍藏库4 小时前
Google Chrome-便携增强版[解压即用]
前端·chrome
子燕若水5 小时前
uv 安装包
开发语言·chrome·python
我的青春不太冷5 小时前
【实战篇章】深入探讨:服务器如何响应前端请求及后端如何查看前端提交的数据
运维·服务器·前端·学习
Anlici6 小时前
2025前端高频面试题--CSS篇
前端·css
追光少年33226 小时前
Learning Vue 读书笔记 Chapter 4
前端·javascript·vue.js