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
相关推荐
Yan-英杰5 小时前
从Free Tier到Serverless:用亚马逊云科技打造零门槛AI应用hugh_oo5 小时前
100 天学会爬虫 · Day 11:如何合理控制爬虫请求频率?让访问行为更像真人xcLeigh5 小时前
HTML5实现好看的视频播放器(三种风格,附源码)TE-茶叶蛋5 小时前
html5-qrcode扫码功能2501_906467635 小时前
HTML5结合Vue3实现百万文件分块上传的思路是什么?San30.5 小时前
现代前端工程化实战:从 Vite 到 React Router demo的构建之旅kirinlau5 小时前
vue3+vite+scss项目使用tailwindcss阿贾克斯的黎明5 小时前
现代前端的魔法标签:HTML5 语义化标签全解析菠菜盼娣5 小时前
vue3知识点