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;
}
JS CRC16/XMODEM
聊者说2024-01-16 12:14
相关推荐
中微子1 分钟前
RESTful架构与前后端路由演进:构建现代化Web应用的核心规范前端付豪2 分钟前
13、表格系统架构:列配置、嵌套数据、复杂交互人生在勤,不索何获-白大侠4 分钟前
day17——Java集合进阶(Collections、Map)南屿im7 分钟前
发布订阅模式和观察者模式傻傻分不清?一文搞懂两大设计模式I_have_a_lemon8 分钟前
前端、产品、设计师神器推荐——Onlook前端小巷子9 分钟前
深入解析CSRF攻击JustHappy10 分钟前
SPA?MPA?有啥关系?有啥区别?聊一聊页面形态 or 路由模式每天开心10 分钟前
🧙♂️闭包应用场景之--防抖和节流hxmmm15 分钟前
webpack多入口打包文件CAD老兵16 分钟前
前端组件库的多主题实现原理与实战指南