node-red 插件使用教程

本文介绍如何使用Java和Californium框架实现CoAP客户端和服务端,演示了CoAP资源的创建与GET请求处理,并展示了Node-RED中coap插件的配置与使用,包括自定义插件、全局变量管理和用户权限设置。
该文章已生成可运行项目,

一  java 编写 coap 客户端与服务端

概述:

CoAP是为物联网而生,短小精悍,它底层基于UDP协议的,其它具体参考百度百科,本例子是基于Californium框架。

1、先决条件
java环境

eclipse工具

Maven插件(有最好,不需要手动下载jar引入,没有的话手动引入)

2、下载Californium框架核心jar
californium-core.jar : 包括CoAP核心部分

element-connector.jar  包括适用于UDP和DTLS的java套接字抽象层

scandium.jar: 包括DTLS

<dependency>
        <groupId>org.eclipse.californium</groupId>
        <artifactId>californium-core</artifactId>
        <version>2.0.0-M7</version>
    </dependency>
    <dependency>
        <groupId>org.eclipse.californium</groupId>
        <artifactId>element-connector</artifactId>
        <version>2.0.0-M7</version>
    </dependency>
  <dependency>
        <groupId>org.eclipse.californium</groupId>
        <artifactId>scandium</artifactId>
        <version>2.0.0-M7</version>
    </dependency>

3、创建java工程或Maven工程,创建一个Server类

import org.eclipse.californium.core.CoapResource;
import org.eclipse.californium.core.CoapServer;
import org.eclipse.californium.core.coap.CoAP.ResponseCode;
import org.eclipse.californium.core.server.resources.CoapExchange;
 
public class HelloCoAPServer {
 
    public static void main(String[] args) {
        CoapServer server = new CoapServer();//主机为localhost 端口为默认端口5683
        server.add(new CoapResource("hello"){//创建一个资源为hello 请求格式为 主机:端口\hello
 
            @Override
            public void handleGET(CoapExchange exchange) { //重写处理GET请求的方法
                exchange.respond(ResponseCode.CONTENT, "Hello CoAP!");  
            }
            
        });
        server.add(new CoapResource("time"){ //创建一个资源为time 请求格式为 主机:端口\time
 
            @Override
            public void handleGET(CoapExchange exchange) {
                Date date = new Date();
                exchange.respond(ResponseCode.CONTENT,
                        new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(date));
            }
            
        });
        server.start();
    }
}


4、创建一个客户端:

public class GETClient {
 
    public static void main(String[] args) throws URISyntaxException {
        URI uri = null;
        uri = new URI("localhost:5683/hello");  //创建一个资源请求hello资源,注意默认端口为5683
        CoapClient client = new CoapClient(uri);
        CoapResponse response = client.get();
        if(response !=null){
            System.out.println(response.getCode());  //打印请求状态码
            System.out.println(response.getOptions());  //选项参数
            System.out.println(response.getResponseText());  //获取内容文本信息
            System.out.println("\nAdvanced\n");    // 
            System.out.println(Utils.prettyPrint(response));  //打印格式良好的输出
        }
    }
}


5、测试
先运行HelloCoAPServer的main方法

然后运行GETClient的main方法

6、日志:

2.05
{"Content-Format":"text/plain"}
Hello CoAP!
 
Advanced
 
==[ CoAP Response ]============================================
MID    : 10763
Token  : [aab3ac5818d1e598]
Type   : ACK
Status : 2.05
Options: {"Content-Format":"text/plain"}
RTT    : 26 ms
Payload: 11 Bytes
---------------------------------------------------------------
Hello CoAP!
===============================================================

二 node-red安装node-red-contrib-coap

 

 

安装之后拖拽配置

coap请求节点配置如下

 

 

coap 服务端节点配置如下

 

服务端响应节点配置如下,获取get请求参数

可以自定义响应的格式,注意访问coap服务器的时候,如果有配置hosts,应该使用hosts访问这个地址

 

三 msyql插件 node-red-node-mysql

1. 安装

2.配置调试

 找到mysql组件,然后编辑节点

 配置新的节点

设置参数

组件连接

sql编写组件

内容

 

 

三 kafka组件

 

输入输出kafka组件

配置添加节点

 

四 http

 

 

部署后访问nodered端口的/test路径

http://127.0.0.1:1880/test?a=1&b=3

 

 

串口插件

使用方式如下博客

https://blog.youkuaiyun.com/geek_monkey/article/details/80755719

串口安装权限异常等问题失败 使用离线安装

sudo npm install node-pre-gyp --save
sudo npm install serialport --unsafe-perm --build-from-source --save
npm i npm to update 
npm install -g serialport

 

node-red 自定义插件

先找到对应的自定义插件所在的目录

 

将后缀的demo删除后重启nodered,输入组件中会多一个sample,即为自定义组件

修改自定义组件内容 99-sample.js

核心部分

 

编码格式为js语法,但是部分api不存在.例如数组遍历map不存在

按照自己的要求修改好之后,重启node-red

 

 

node-red全局变量

使用函数组件

编辑内容

if (local.action===undefined)//获取全局变量,如果不存在,赋默认值
{
  local.action="站立";
  local.x=0;
  local.y=0;
}else{//如果存在,进入计算
    switch(msg.payload.token){
        case "move_x":
            local.x+=parseInt(msg.payload.value)
            break;
        case "move_y":
             local.y+=parseInt(msg.payload.value)
            break;
    }
}
context.set('data',local);//保存全局变量

函数节点使用16进制字节数组

msg.payload = Buffer.from([0x12,0x22,0xd3,0x23])

 

node-red的用户权限与密码配置

首先找到配置文件,启动node-red的时候,启动日志会显示配置文件位置,如下图所示

修改配置文件

找到这个位置,放开注释

password是经过加密处理的

permissions 表示用户权限,分为 读写 -> *    只读  -> read

获取加密后的秘钥

首先进入找到加密工具所在的目录

进入开始转化秘钥

node -e "console.log(require('bcryptjs').hashSync(process.argv[1], 8));" mypassword

 

得到的$2a$08$Dk6dTjxEPi85sObY1HRYZ.QDoB53m/J5M1MFulhgKTvpwuuC5AzOW表示新的秘钥,将他写入配置文件setting中的pasword中,即下一次登录使用的密码为mypassword

本文章已经生成可运行项目
### Node-RED 使用教程 #### 安装准备 为了顺利安装并运行Node-RED,需先确认目标机器已成功安装Node.js环境。这一步骤至关重要,因为Node-RED依赖于Node.js来执行JavaScript代码[^1]。 #### 安装方法 利用npm(Node Package Manager),即Node.js自带的软件包管理系统来进行Node-RED的安装工作。命令行输入`npm install -g --unsafe-perm node-red`即可完成全局安装,使得可以在任何位置调用Node-RED命令。 对于希望采用Docker方式部署Node-RED的情况,则可以通过定义特定的环境变量来自定义容器内部的行为模式。例如指定Node.js版本(`NODE_VERSION`)、Yarn版本(`YARN_VERSION`)以及Node-RED本身的具体版本号(`NODE_RED_VERSION`)等参数,在创建镜像时通过`.env`文件或者直接在`docker-compose.yml`中声明这些变量实现个性化配置[^2]。 #### 初始界面概览 首次启动后打开浏览器访问http://localhost:1880,默认进入的是编辑页面而非运行状态下的仪表板视图。左侧栏展示了各种可用节点类别;中央区域用于拖拽放置及连线构建逻辑关系的工作区;右侧则是属性设置面板,允许调整所选组件的各项细节选项[^4]。 #### 基本操作指南 - **添加新节点**:从左边菜单里挑选合适的图标代表不同功能单元(比如HTTP请求接收端口),点击拖放到中间空白处释放。 - **连接各部分**:鼠标悬停选定源点直到出现绿色箭头提示符,按住左键拉向目的地松开形成一条有方向性的线段表示数据流动路径。 - **保存项目结构**:任何时候只要做了改动都应及时按下右上方“Deploy”按钮同步至服务器端生效,同时也会自动存盘以防丢失进度。 - **调试测试流程**:借助内置Debug抽屉实时监控消息传递情况,便于快速定位错误所在环节进行修正优化[^3]。 ```bash # 启动Node-RED服务实例 node-red-start ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小钻风巡山

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值