【物联网开发】、【小程序蓝牙通讯数据校验】JS CRC-16-MODBUS 验证 高位在前地位在后;JS异或校验;16进制字符串和float互转

1.CRC校验

javascript 复制代码
/*计算CRC-16/MODBUS校验位高低位*/
function calculateCRC16Modbus(dataHexString) {
	const dataBytes = [];
	for (let i = 0; i < dataHexString.length; i += 2) {
		dataBytes.push(parseInt(dataHexString.substr(i, 2), 16));
	}

	let crc = 0xFFFF;
	const polynomial = 0xA001; // This is the polynomial x^16 + x^15 + x^2 + 1

	for (const byte of dataBytes) {
		crc ^= byte;
		for (let i = 0; i < 8; i++) {
			if (crc & 0x0001) {
				crc = ((crc >> 1) ^ polynomial) & 0xFFFF;
			} else {
				crc >>= 1;
			}
		}
	}

	crc = pad(crc.toString(16).toUpperCase(),4);//补0(不然会出八阿哥)
	let crcArr = new Array(2)
	console.log('crc='+crc)
	crcArr[0] = crc.substring(2, 4)
	crcArr[1] = crc.substring(0, 2)
	let code = crcArr[0] + crcArr[1]
	return code
}

2.异或校验

javascript 复制代码
// 生成校验码
function genCheckCode(msgBodyCode) {
	let firstByte = null;
	for (let i = 0; i < msgBodyCode.length; i = i + 2) {
		const curCode = '0x' + msgBodyCode.substring(i, i + 2);
		if (i == 0) {
			firstByte = curCode
		} else {
			firstByte = firstByte ^ curCode
		}
	}
	firstByte = parseInt(firstByte)
	const codePad = pad(firstByte.toString(16), 2)
	console.log('校验码==' + codePad)
	return codePad;
}

3.pad 左侧补0方法

javascript 复制代码
// 左侧补齐0
function pad(str, max) {
	str = str.toString();
	return str.length < max ? pad("0" + str, max) : str;
}

4.16进制和float(4字节)互转

javascript 复制代码
/*4字节byte十六进制转浮点数      解析   */
function hex2float(hexString, precision) {
	//hex2float('EC519A44', 2))
	precision = parseInt(precision)
	if (isNaN(precision) || precision < 0) {
		precision = 2
	}

	// 高低位转换
	const byteArray = [];
	for (let i = 0; i < hexString.length; i += 2) {
		byteArray.unshift(hexString.substr(i, 2));
	}

	// 创建一个包含十六进制数的 ArrayBuffer
	const hexValue = '0x' + byteArray.join('');
	const buffer = new ArrayBuffer(4);
	const dataView = new DataView(buffer);
	dataView.setUint32(0, hexValue, false);

	// 从 DataView 中读取浮点数
	const floatValue = dataView.getFloat32(0, false);
	return floatValue.toFixed(precision);
}


/*浮点数转4字节十六进制      发送*/
function float2hex(floatNumber) {
	// 创建一个 4 字节的 ArrayBuffer
	const buffer = new ArrayBuffer(4);

	// 使用 DataView 来操作 ArrayBuffer
	const dataView = new DataView(buffer);

	// 将浮点数写入到 DataView 中
	dataView.setFloat32(0, floatNumber, false); // 第二个参数是偏移量,false 表示使用大端字节序

	// 从 DataView 中读取十六进制表示
	const hexString = dataView.getUint32(0, false).toString(16).toUpperCase();

	// 高低位转换
	const byteArray = [];
	for (let i = 0; i < hexString.length; i += 2) {
		byteArray.unshift(hexString.substr(i, 2));
	}
	return byteArray.join('');
}
相关推荐
魔术师ID1 分钟前
vue 指令
前端·javascript·vue.js
凌冰_3 分钟前
CSS3 变形
前端·css·css3
芯眼16 分钟前
STM32启动文件详解(重点)
java·开发语言·c++·stm32·单片机·mybatis
Clown9531 分钟前
Go语言爬虫系列教程 实战项目JS逆向实现CSDN文章导出教程
javascript·爬虫·golang
愚润求学44 分钟前
【Linux】动静态库链接原理
linux·运维·服务器·开发语言·笔记
GISer_Jing1 小时前
前端图形渲染 html+css、canvas、svg和webgl绘制详解,各个应用场景及其区别
前端·html·图形渲染
呦呦彬1 小时前
【问题排查】easyexcel日志打印Empty row!
java·开发语言·log4j
零凌林1 小时前
使用exceljs将excel文件转化为html预览最佳实践(完整源码)
前端·html·excel·vue3·最佳实践·文件预览·exceljs
星空寻流年1 小时前
css3基于伸缩盒模型生成一个小案例
javascript·css·css3
二十雨辰1 小时前
[CSS3]属性增强1
前端·css·css3