Spring Boot集成udp通讯

Spring Boot集成udp通讯

  • 加入依赖
  • 编辑配置文件
  • 配置相关属性
  • 具体业务类
  • 客户端
  • 调试

加入依赖

<!--加入UDP通信所需依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-integration</artifactId><exclusions><exclusion><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId></exclusion></exclusions></dependency><dependency><groupId>org.springframework.integration</groupId><artifactId>spring-integration-ip</artifactId></dependency>

编辑配置文件

application.yml

# 和嵌入式udp通信的发送端口和监听端口地址
udp:listeningPort: 9911sendingPort: 9911

配置相关属性


@Component
@ConfigurationProperties(prefix = "udp")
public class UdpConfig {/*** 与嵌入式通信的udp监听端口*/private static Integer listeningPort;/*** 与嵌入式通信的udp发送端口*/private static Integer sendingPort;@Value("${udp.listeningPort}")public void setListeningPort(Integer listeningPort) {this.listeningPort = listeningPort;}@Value("${udp.sendingPort}")public void setSendingPort(Integer sendingPort) {this.sendingPort = sendingPort;}public static Integer getListeningPort() {return listeningPort;}public static Integer getSendingPort() {return sendingPort;}
}

具体业务类


@Configuration
public class UdpServer {private static final Logger logger = LoggerFactory.getLogger(UdpServer.class);/*** UDP消息接收服务*/@Beanpublic IntegrationFlow integrationFlow() {logger.info("UDP服务启动成功,端口号为: {}", UdpConfig.getListeningPort());return IntegrationFlows.from(Udp.inboundAdapter(UdpConfig.getListeningPort())).channel("udpChannel").get();}/*** 转换器*/@Transformer(inputChannel = "udpChannel", outputChannel = "udpFilter")public String transformer(@Payload byte[] payload, @Headers Map<String, Object> headers) {String message = new String(payload);// todo 进行数据转换message = message.toUpperCase();return message;}/*** 过滤器*/@Filter(inputChannel = "udpFilter", outputChannel = "udpRouter")public boolean filter(String message, @Headers Map<String, Object> headers) {// 获取来源IdString id = headers.get("id").toString();// 获取来源IP,可以进行IP过滤String ip = headers.get("ip_address").toString();// 获取来源PortString port = headers.get("ip_port").toString();// todo 信息数据过滤
//        if (true) {
//            // 没有-的数据会被过滤
//            return false;
//        }return true;}/*** 路由分发处理器:可以进行分发消息被那个处理器进行处理*/@Router(inputChannel = "udpRouter")public String router(String message, @Headers Map<String, Object> headers) {// 获取来源IdString id = headers.get("id").toString();// 获取来源IP,可以进行IP过滤String ip = headers.get("ip_address").toString();// 获取来源PortString port = headers.get("ip_port").toString();// todo 筛选,走那个处理器if (true) {return "udpHandle2";}return "udpHandle1";}/*** 最终处理器1*/@ServiceActivator(inputChannel = "udpHandle1")public void udpMessageHandle(String message) throws Exception {// todo 可以进行异步处理logger.info("message:" + message);}/*** 最终处理器2*/@ServiceActivator(inputChannel = "udpHandle2")public void udpMessageHandle2(String message) throws Exception {logger.info("UDP2:" + message);//接受消息处理业务}public void sendMsg(String message) {byte[] bytes = message.getBytes();UnicastSendingMessageHandler handler = new UnicastSendingMessageHandler("localhost", UdpConfig.getSendingPort());logger.info("发送UDP信息: {" + bytes + "}");handler.handleMessage(MessageBuilder.withPayload(bytes).build());logger.info("发送成功");}
}

客户端


@RestController
@RequestMapping("/udp")
public class UdpClient {private final static Logger logger = LoggerFactory.getLogger(UdpClient.class);@PostMapping("/send")public BaseResult send(@RequestParam("message") String message) {byte[] bytes = message.getBytes();UnicastSendingMessageHandler handler = new UnicastSendingMessageHandler("localhost", UdpConfig.getSendingPort());logger.info("发送UDP信息: {" + bytes + "}");handler.handleMessage(MessageBuilder.withPayload(bytes).build());logger.info("发送成功");return new BaseResult<>();}
}

调试

接口请求客户端地址{ip:host}/udp/send
在这里插入图片描述
debug查看 成功接收到消息

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3281349.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

【PCB设计原则5】-PCB设计的寄生元件

寄生电容 在PCB上布两条靠近的走线&#xff0c;很容易形成寄生电容。由于这种电容的存在&#xff0c;在一条走线上的快速电压变化&#xff0c;可在另一条走线上产生电流信号。 设计电路板时&#xff0c;放置两条彼此靠近的走线就会产生寄生电容。例如,在不同的两层&#xff0c…

OJ-0731

题目 题解 参考 import java.util.Arrays; import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner new Scanner(System.in);while (scanner.hasNext()) {int xmh scanner.nextInt();int n scanner.nextInt();int[] COs …

SFP, SFP+,QSFP光模块封装类型

前言&#xff1a; 本文是自己对SFP, SFP,QSFP光模块封装类型的学习记录&#xff0c;所有的资料都搜集字引用链接里的博客内容&#xff0c;本文更多的是自己的学习笔记记录所以可能会有一些理解错误&#xff0c;请更多的参考引用链接里的信息来源。 引用&#xff1a; 认识SFP/SF…

Arduino Mega 2560开发板的引脚分配图及说明,以及链接can的方法

与Arduino Uno相比,Arduino Mega2560的资源就丰富多了,它具有54个数字I/O口(其中14个可提供PWM输出),16个模拟I/O口,4对串行数据通信口(UART),一个复位开关,一个ICSP下载口,支持USB接口和直流电源供电,具体的资源分配见下图。 Arduino Mega 2560开发板的引脚分配…

nginx代理设置时能获取到源IP地址的方法

nginx通过http_x_forwarded_for限制来访IP示例_ngnix 根据header的x-forwarded-for限制接入-CSDN博客 名称ip客户端地址10.0.23.90nginx服务器地址110.0.202.48:18888&#xff0c;代理到10.0.204.82:8888nginx服务器地址210.0.204.82:8888&#xff0c;代理到10.0.204.82:8887后…

Yarn UI 时间问题,相差8小时

位置 $HADOOP_HOME/share/hadoop/yarn/hadoop-yarn-common-2.6.1.jar 查看 jar tf hadoop-yarn-common-2.6.1.jar |grep yarn.dt.plugins.js webapps/static/yarn.dt.plugins.js 解压 jar -xvf hadoop-yarn-common-2.6.1.jar webapps/static/yarn.dt.plugins.js inflated: we…

Windows本地构建镜像推送远程仓库

下载 Docker Desktop https://smartidedl.blob.core.chinacloudapi.cn/docker/20210926/Docker-win.exe 使用本地docker构建镜像和推送至远程仓库&#xff08;harbor&#xff09; 1、开启docker的2375端口 2、配置远程仓库push镜像可以通过http harbor.soujer.com:5000ps&am…

【转型必看】Java到AI,程序员的逆袭秘籍,转行人工智能不再是梦!

随着技术的不断进步&#xff0c;人工智能&#xff08;AI&#xff09;已经成为当今科技领域最热门的话题之一。许多开发者开始考虑从传统的软件开发领域&#xff0c;如Java&#xff0c;转向人工智能领域&#xff0c;今天小编和大家一起来探讨Java开发者是否可以转型到人工智能&a…

Python中导入不同文件夹中的函数

1、代码举例&#xff1a;from Python_CodeFile.LDAP3.del_file.Get_Computer_Dn import get_computer_dn # 以上代码导入路径为&#xff1a;Python_CodeFile/LDAP3/del_file/Get_Computer_Dn.py 文件中的get_computer_dn函数。

计算机网络知识点面试总结5

#来自ウルトラマンゼロ&#xff08;赛罗&#xff09; 1 网络应用模型 1.1 客户/服务器模型 总是打开一个主机称为服务器&#xff0c;服务与其他客户机的请求。 1.2 P2P 模型 任意一对计算机-称为对等方&#xff0c;直接相互通信。(每一台计算机既是客户机&#xff0c;又是服务…

谷粒商城实战笔记-99-仓储服务-API-仓库管理-完成采购

文章目录 一&#xff0c;业务逻辑分析二&#xff0c;模拟调用和效果1&#xff0c;Postman模拟调用2&#xff0c;页面效果 三&#xff0c;代码总结1 分页插件配置2 服务间接口调用的不同方式直接访问服务通过网关访问服务小小结 一&#xff0c;业务逻辑分析 采购负责人在完成采…

算法板子:DFS(深度优先搜索、暴搜)——寻找1~n这n个数的所有排列方案

思想&#xff1a;深搜会一条路走到黑&#xff0c;把所有的位置都填满&#xff0c;如下图中的路径1&#xff1a; 代码——重点在dfs函数&#xff1a; #include <iostream> using namespace std;const int N 7; int n;// st[i]代表i这个数有没有被用过; 比如st[1]false代…

希尔排序【C语言】

希尔排序 前言 在上一篇文章中我们了解了直接插入排序算法&#xff08;建议先阅读&#xff09;&#xff0c;但其实这个算法还是有一定优化空间的。而它优化之后&#xff0c;就变成了另一个大名鼎鼎的排序算法&#xff1a;希尔排序。 希尔排序(Shell’s Sort)是插入排序的一种…

C语言中的浮点数存储:深入探讨

案例引入 请看下面一段代码并思考结果&#xff1a; #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> int main() {int n 9;float* pFloat (float*)&n;printf("n的值为&#xff1a;%d\n", n);printf("*pFloat的值为&#xff1a;%f\n", *…

Java线程阻塞:原因

Java线程阻塞&#xff1a;原因 1. sleep()2. suspend() 和 resume()&#xff08;不推荐&#xff09;3. yield()4. wait() 和 notify()/notifyAll() &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 线程阻塞是一个重要的概念&#xff0c;它决…

Linux下docker部署drools并集成项目使用

Linux下docker部署drools并集成项目使用 一、背景介绍二、 思路方案三、过程四、总结 一、背景介绍 上一篇文章是对规则引擎的基本介绍&#xff0c;本篇文章是对于drools规则引擎的基本使用。 二、 思路方案 前提&#xff1a;首先保证主机联网、有docker环境、保证Linux空闲…

OS—文件系统

目录 一. 文件系统结构I/O 控制层基本文件系统文件组织模块逻辑文件系统 二. 文件系统布局文件系统在磁盘中的结构主引导记录(MasterBoot Record,MBR)引导块(boot block)超级块(super block)文件系统中空闲块的信息 文件系统在内存中的结构 三. 外存空间管理空闲表法空闲链表法…

面向对象 - 概述、类的创建、 实例化与内存解析

一、学习面向对象的三条主线 Java类及类的成员&#xff1a;&#xff08;重点&#xff09;属性、方法、构造器&#xff1b;&#xff08;熟悉&#xff09;代码块、内部类面向对象的特征&#xff1a;封装、继承、多态、&#xff08;抽象&#xff09;其他关键字的使用&#xff1a;…

北欧风情在浦东,5 大公司为你定制美好

在繁华的浦东&#xff0c;追求高品质生活的您&#xff0c;是否渴望拥有一个充满北欧风情的温馨家园&#xff1f;今天&#xff0c;我们将为您推荐 5 家顶尖的装修公司&#xff0c;它们将以精湛的工艺和独特的设计理念&#xff0c;为您量身定制梦想中的北欧风家居。 推荐一&#…

大数据-56 Kafka SpringBoot与Kafka 基础简单配置和使用

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…