【物联网开发】、【小程序蓝牙通讯数据校验】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('');
}
相关推荐
好_快1 小时前
Lodash源码阅读-memoizeCapped
前端·javascript·源码阅读
好_快1 小时前
Lodash源码阅读-toString
前端·javascript·源码阅读
好_快1 小时前
Lodash源码阅读-memoize
前端·javascript·源码阅读
excel1 小时前
webpack 核心编译器 十四 节
前端
excel1 小时前
webpack 核心编译器 十三 节
前端
腾讯TNTWeb前端团队8 小时前
helux v5 发布了,像pinia一样优雅地管理你的react状态吧
前端·javascript·react.js
范文杰12 小时前
AI 时代如何更高效开发前端组件?21st.dev 给了一种答案
前端·ai编程
拉不动的猪12 小时前
刷刷题50(常见的js数据通信与渲染问题)
前端·javascript·面试
拉不动的猪12 小时前
JS多线程Webworks中的几种实战场景演示
前端·javascript·面试
FreeCultureBoy13 小时前
macOS 命令行 原生挂载 webdav 方法
前端