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;
  }
相关推荐
不写八个5 分钟前
Python办公自动化教程(005):Word添加段落
开发语言·python·word
HEX9CF9 分钟前
【CTF Web】Pikachu xss之href输出 Writeup(GET请求+反射型XSS+javascript:伪协议绕过)
开发语言·前端·javascript·安全·网络安全·ecmascript·xss
凌云行者22 分钟前
使用rust写一个Web服务器——单线程版本
服务器·前端·rust
赵荏苒34 分钟前
Python小白之Pandas1
开发语言·python
丶Darling.36 分钟前
代码随想录 | Day26 | 二叉树:二叉搜索树中的插入操作&&删除二叉搜索树中的节点&&修剪二叉搜索树
开发语言·数据结构·c++·笔记·学习·算法
华农第一蒟蒻38 分钟前
Java中JWT(JSON Web Token)的运用
java·前端·spring boot·json·token
积水成江39 分钟前
关于Generator,async 和 await的介绍
前端·javascript·vue.js
Z3r4y40 分钟前
【Web】portswigger 服务端原型污染 labs 全解
javascript·web安全·nodejs·原型链污染·wp·portswigger
___Dream41 分钟前
【黑马软件测试三】web功能测试、抓包
前端·功能测试
金灰41 分钟前
CSS3练习--电商web
前端·css·css3