Nodejs 串口通信 : websocket , serialport

2024-09-07 02:48

本文主要是介绍Nodejs 串口通信 : websocket , serialport,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在学习如何实现web页面和串口间通信,网页请求使用websocket,实现的基本功能如下:

1、基本需求:硬件:有两个信号灯(TLA-505-1T),一个485继电器(开关),电压转换器,工业触屏一体机。

2、原理图:

                

3工作原理:

首先一体机中采用node开发服务器,网页请求采用websocket协议,直接放代码了:

var express = require('express');
var SerialPort = require('serialport');
var app = express();
var expressWs = require('express-ws')(app);
var util = require('util');
/*
var com =require('./com.js');
var logger = require('./log.js').logger;
*/


app.use(express.static('public'));
//ejs
app.set('view engine','ejs');app.get('/',function(req,res){res.render('control');
})app.ws('/ws', function(ws, req) {util.inspect(ws);ws.on("message",function(str){console.log('1234');//hander(str,ws);});ws.on("close",function(code,reason){console.log('connection closed');})//处理错误事件信息
    ws.on('error',function(err){console.log('throw err',err);})})
function hander(str,ws) {//发送数据到客户端
    //console.log(str);
    var arr = str.split('');if(arr[2]==1){//close
        arr[2]=0;}else{arr[2]=1;}//console.log(arr.join(''));
    ws.send(arr.join(''));
}app.listen(3004);

这样一个server服务写好,然后在写html界面:

<!DOCTYPE html>
<html lang="en">
<head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="js/jquery.mobile-1.4.5.min.css">
<script src="js/jquery-1.11.3.min.js"></script>
<script src="js/jquery.mobile-1.4.5.min.js"></script><title>Title</title><style>form{margin: 30px auto;width: 35%;}</style></head>
<body>
<br>
<form class="form"><fieldset><legend>websocket 控制</legend><br><br><div>  <button type="button" style="background: #EEF9F3" id="deng1" value="100">灯1关闭状态</button><button type="button" style="background: #EEF9F3" id="deng2" value="110">灯2关闭状态</button></div><br><span id='content'>客户端未连接</span></br><input type="button" value="连接" id="connect" class="connect"/></fieldset>
</form>
<script>var oUl=document.getElementById('content');var oConnect=document.getElementById('connect');var oSend=document.getElementById('send');var oInput=document.getElementById('message');var ws=null;oConnect.onclick=function(){ws = new WebSocket('ws://localhost:3004/ws');ws.onopen=function(){document.getElementById('content').innerHTML = "客户端已连接";}ws.onmessage=function(evt){ //document.getElementById('states').innerHTML = "deng : "+evt.data
            var arr = evt.data.split('');if(arr[1]==0){//deng1
                var deng = "deng1";changeState(deng,'states1');}else if(arr[1]==1){//deng2
                var deng = "deng2";changeState(deng,'states2');} function changeState(deng,state){$('#'+deng).val(evt.data);if(arr[2]==1){//open 
                   // document.getElementById(state).innerHTML = deng+" open:"+evt.data;
                    document.getElementById(deng).innerHTML = (deng =='deng1'?'灯1':'灯2')+"关闭状态";$('#'+deng).css("background-color","#B3B4A6");}else if(arr[2]==0){// document.getElementById(state).innerHTML = deng+" close:"+evt.data;
                    document.getElementById(deng).innerHTML = (deng =='deng1'?'灯1':'灯2')+"打开状态";$('#'+deng).css("background-color","#EEF9F3");}}   }ws.onclose=function(){document.getElementById('content').innerHTML = "客户端已断开连接";};ws.onerror=function(evt){oUl.innerHTML+="<li>"+evt.data+"</li>";};};//$(document).on("pagecreate","#pageone",function(){
      $("#deng1").on("tap",function(){  ws.send($("#deng1").val());});                       
//});
      $("#deng2").on("tap",function(){ ws.send($("#deng2").val());});  /*function clickDend(val){
        console.log(val)
        if(ws){
            ws.send(val);
        }
    }*/
</script>
</body>
</html>

这样一个完整的websocket协议完成,最后在socket协议中加入串口通信:

var express = require('express');
var SerialPort = require('serialport');
var app = express();
var expressWs = require('express-ws')(app);
var util = require('util');
var com =require('./com.js');
/*
var com =require('./com.js');
var logger = require('./log.js').logger;
*/


app.use(express.static('public'));
//ejs
app.set('view engine','ejs');app.get('/',function(req,res){res.render('control');
})app.ws('/ws', function(ws, req) {util.inspect(ws);var sendDelay = 2000;ws.on("message",function(str){console.log('1234');var arr = str.split('');if(arr[2]==1){//close
            arr[2]=0;}else{arr[2]=1;}sendData(arr,ws);//setInterval(sendData,sendDelay);

    });ws.on("close",function(code,reason){console.log('connection closed');})//处理错误事件信息
    ws.on('error',function(err){console.log('throw err',err);})})var defaults = {//reportVersionTimeout: 5000,
    receiveInterval: 100,sendInterval: 500,repeatSendTimes: 30,  // ??????
    SerialName:'/dev/ttyAMA0',SerialPort: {baudRate: 9600,autoOpen: false,parity: 'none',xon: false,xoff: false,xany: false,rtscts: false,hupcl: true,dataBits: 8,stopBits: 1,bufferSize: 11
    }
};var SerialPort = com.SerialPort;
//logger.info('List all serialport');
SerialPort.list(function (err, ports) {ports.forEach(function(port) {console.log(port.comName);console.log(port.pnpId);console.log(port.manufacturer);});
});var test = new com.SerialPort(defaults.SerialName, defaults.SerialPort);var count=0;
var sendTime = Date.now();
test.on('data', function (data) {console.log("receive:"+util.inspect(data));count++;var elapsed = Date.now() - sendTime;console.log("count:"+count+",elapsed:"+elapsed+" ms");
});test.on('error',function (err){console.log("error:"+err);
});test.on('close',function (){console.log("close occured");
});test.open(function (error) {console.log(error);console.log('com port opened');});var cmd1 = Buffer.from([0xaa,0x07,0xde,0x03,0x03,0x01,0x27,0x34,0x10,0x08,0x09]);
var cmd2 = Buffer.from([0xaa,0x07,0xde,0x03,0x03,0x01,0x27,0x34,0x10,0x02,0x03]);
var cmd3 = Buffer.from([0xFE,0x05,0x00,0x00,0xFF,0x00,0x98,0x35]);
var cmd4 = Buffer.from([0xFE,0x05,0x00,0x00,0x00,0x00,0xD9,0xC5]);var cmd5 = Buffer.from([0xFE,0x05,0x00,0x01,0xFF,0x00,0xc9,0xf5]);
var cmd6 = Buffer.from([0xFE,0x05,0x00,0x01,0x00,0x00,0x88,0x05]);var sendCount = 0;
function sendData(arr,ws){console.log("send count:"+arr[1]);if(arr[1]==0){if(arr[2]==0){test.write(cmd3); //灯1 打开
            arr[2]==1;}else if(arr[2]==1){test.write(cmd4);  //灯1 关闭
            arr[2]==0;}}else if(arr[1]==1){if(arr[2]==0){test.write(cmd5); //灯1 打开
            arr[2]==1;}else if(arr[2]==1){test.write(cmd6);  //灯1 关闭
            arr[2]==0;}}ws.send(arr.join(''));
}app.listen(3004);
ok,就可以在一体机上单机按钮,控制灯的开关啦。






这篇关于Nodejs 串口通信 : websocket , serialport的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1143845

相关文章

SpringBoot实现websocket服务端及客户端的详细过程

《SpringBoot实现websocket服务端及客户端的详细过程》文章介绍了WebSocket通信过程、服务端和客户端的实现,以及可能遇到的问题及解决方案,感兴趣的朋友一起看看吧... 目录一、WebSocket通信过程二、服务端实现1.pom文件添加依赖2.启用Springboot对WebSocket

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

vue2 组件通信

props + emits props:用于接收父组件传递给子组件的数据。可以定义期望从父组件接收的数据结构和类型。‘子组件不可更改该数据’emits:用于定义组件可以向父组件发出的事件。这允许父组件监听子组件的事件并作出响应。(比如数据更新) props检查属性 属性名类型描述默认值typeFunction指定 prop 应该是什么类型,如 String, Number, Boolean,

Java Websocket实例【服务端与客户端实现全双工通讯】

Java Websocket实例【服务端与客户端实现全双工通讯】 现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发 出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏 览器需要不断的向服务器发出请求,然而HTTP

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(

nvm及nodejs安装相关

安装 1.清空文件夹,卸载nvm及nodejs 2.下载安装包 https://github.com/coreybutler/nvm-windows/releases (也下载有) 3.安装nvm 地址写D:/nvm和D:/nodejs 4.安装nodejs nvm ls available //查询版本nvm install 16.20.2 //安装对应版本号nvm use 1

C++编程:ZeroMQ进程间(订阅-发布)通信配置优化

文章目录 0. 概述1. 发布者同步发送(pub)与订阅者异步接收(sub)示例代码可能的副作用: 2. 适度增加缓存和队列示例代码副作用: 3. 动态的IPC通道管理示例代码副作用: 4. 接收消息的超时设置示例代码副作用: 5. 增加I/O线程数量示例代码副作用: 6. 异步消息发送(使用`dontwait`标志)示例代码副作用: 7. 其他可以考虑的优化项7.1 立即发送(ZMQ_IM

安卓开发板_联发科MTK开发评估套件串口调试

串口调试 如果正在进行lk(little kernel ) 或内核开发,USB 串口适配器( USB 转串口 TTL 适配器的简称)对于检查系统启动日志非常有用,特别是在没有图形桌面显示的情况下。 1.选购适配器 常用的许多 USB 转串口的适配器,按芯片来分,有以下几种: CH340PL2303CP2104FT232 一般来说,采用 CH340 芯片的适配器,性能比较稳定,价