记录一个springboot 2.5 带返回的udp适配器

package com.xxxxxx.framework.config;

import com.alibaba.fastjson.JSONObject;
import com.inho.common.core.redis.RedisCache;
import com.inho.framework.websocket.WebSocketServerCommon;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.integration.annotation.Filter;
import org.springframework.integration.annotation.Router;
import org.springframework.integration.annotation.ServiceActivator;
import org.springframework.integration.annotation.Transformer;
import org.springframework.integration.config.EnableIntegration;
import org.springframework.integration.dsl.IntegrationFlow;
import org.springframework.integration.dsl.IntegrationFlows;
import org.springframework.integration.dsl.MessageChannels;
import org.springframework.integration.ip.dsl.Udp;
import org.springframework.integration.ip.udp.UnicastSendingMessageHandler;
import org.springframework.integration.support.MessageBuilder;
import org.springframework.messaging.MessageChannel;
import org.springframework.messaging.handler.annotation.Header;
import org.springframework.messaging.handler.annotation.Headers;
import org.springframework.messaging.handler.annotation.Payload;

import java.io.IOException;
import java.net.*;
import java.util.Map;

/**
 * UDP消息接收服务
 *
 * @author wliduo[i@dolyw.com]
 * @date 2020/5/20 14:16
 */
@Configuration
@EnableIntegration
public class UdpListener {

    private static final Logger logger = LoggerFactory.getLogger(UdpListener.class);
    @Autowired
    private RedisCache redisCache;
    @Value("${inho.udp.port}")
    private Integer udpPort;


    /**
     * UDP消息接收服务写法一
     * https://docs.spring.io/spring-integration/reference/html/ip.html#inbound-udp-adapters-java-configuration
     *
     * @param
     * @return org.springframework.integration.ip.udp.UnicastReceivingChannelAdapter
     * @throws
     * @author wliduo[i@dolyw.com]
     * @date 2020/5/14 11:00
     */
    /*@Bean
    public UnicastReceivingChannelAdapter unicastReceivingChannelAdapter() {
        // 实例化一个UDP消息接收服务
        UnicastReceivingChannelAdapter unicastReceivingChannelAdapter = new UnicastReceivingChannelAdapter(udpPort);
        // unicastReceivingChannelAdapter.setOutputChannel(new DirectChannel());
        unicastReceivingChannelAdapter.setOutputChannelName("udpChannel");
        logger.info("UDP服务启动成功,端口号为: {}", udpPort);
        return unicastReceivingChannelAdapter;
    }*/

    /**
     * UDP消息接收服务写法二
     * https://docs.spring.io/spring-integration/reference/html/ip.html#inbound-udp-adapters-java-dsl-configuration
     *
     * @param
     * @return org.springframework.integration.dsl.IntegrationFlow
     * @throws
     * @author wliduo[i@dolyw.com]
     * @date 2020/5/20 16:08
     */
    @Bean
    public IntegrationFlow integrationFlow()  {
        logger.info("UDP服务启动成功,端口号为: {}", udpPort);


        return IntegrationFlows.from(Udp.inboundAdapter(udpPort)).channel("udpChannel")  .get();
    }

    /**
     * .handle((payload, headers) -> {
     *                     String message = new String((byte[]) payload);
     *                     String response = " i am response 22, " + message;
     *                     return response.getBytes();
     *                 }).handle(Udp.outboundAdapter("'udp://127.0.0.1:10000'"))
     *
     * **/
    //可返回例子
  /*  @Bean
    public IntegrationFlow udpInboundFlow() {
        return IntegrationFlows.from(Udp.inboundAdapter(udpPort))
                .handle((payload, headers) -> {
                    String message = new String((byte[]) payload);
                    String response = " i am response , " + message;
                    return response.getBytes();
                })
                .handle(Udp.outboundAdapter("'udp://127.0.0.1:10000'"))
                .get();
    }*/
    /**
     * 转换器
     *
     * @param payload
     * @param headers
     * @return java.lang.String
     * @throws
     * @author wliduo[i@dolyw.com]
     * @date 2020/5/20 15:30
     */
    @Transformer(inputChannel = "udpChannel", outputChannel = "udpFilter")
    public String transformer(@Payload byte[] payload, @Headers Map<String, Object> headers) {
        String message = new String(payload);
        // 转换为大写
        // message = message.toUpperCase();
        // 向客户端响应,还不知道怎么写
        return message;
    }



    /**
     * 过滤器
     *
     * @param message
     * @param headers
     * @return boolean
     * @throws
     * @author wliduo[i@dolyw.com]
     * @date 2020/5/20 15:30
     */
    @Filter(inputChannel = "udpFilter", outputChannel = "udpRouter" )
    public boolean filter(String message, @Headers Map<String, Object> headers) {
        // 获取来源Id
        String id = headers.get("id").toString();
        // 获取来源IP,可以进行IP过滤
        String ip = headers.get("ip_address").toString();
        // 获取来源Port
        String port = headers.get("ip_port").toString();
        // 信息数据过滤
        /*if (message.indexOf("-") < 0) {
            // 没有-的数据会被过滤
            return false;
        }*/
        return true;
    }

    /**
     * 路由分发处理器
     *
     * @param message
     * @param headers
     * @return java.lang.String
     * @throws
     * @author wliduo[i@dolyw.com]
     * @date 2020/5/20 15:35
     */
    @Router(inputChannel = "udpRouter")
    public String router(String message, @Headers Map<String, Object> headers) {
        // 获取来源Id
        String id = headers.get("id").toString();
        // 获取来源IP,可以进行IP过滤
        String ip = headers.get("ip_address").toString();
        // 获取来源Port
        String port = headers.get("ip_port").toString();
        // 筛选,走那个处理器
        if (false) {
            return "udpHandle2";
        }
        return "udpHandle1";
    }

    private String handleMessage(String payload) {
        // 处理接收到的数据
        String response = "Processed: " + payload;
        // 响应客户端
        try (DatagramSocket socket = new DatagramSocket()) {
            byte[] responseData = response.getBytes();
            DatagramPacket packet = new DatagramPacket(responseData, responseData.length, InetAddress.getLocalHost(), 10000);
            socket.send(packet);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return response;
    }

    /**
     * 最终处理器1
     *
     * @param message
     * @return void
     * @throws
     * @author wliduo[i@dolyw.com]
     * @date 2020/5/20 15:12
     */

    @ServiceActivator(inputChannel = "udpHandle1",outputChannel = "replyChannel")
    public void  udpMessageHandle(String message) throws Exception {
        // 可以进行异步处理
        String mapKey ="";
        message = message.trim();
        if(message!=null && message.startsWith("{") && message.endsWith("}")){
            JSONObject jsonObject = JSONObject.parseObject(message) ;
            mapKey = jsonObject.getString("action");
            WebSocketServerCommon.sendInfo(message,mapKey);
            redisCache.setCacheMapValue("groundExperatureDriver",mapKey,jsonObject.toString());
            handleMessage( jsonObject.toString());
        }else {
            logger.error("UDP 掉用参数错误,请检查,参数内容为"+ message);
        }
    }



    /**
     * 最终处理器2
     *
     * @param message
     * @return void
     * @throws
     * @author wliduo[i@dolyw.com]
     * @date 2020/5/14 11:02
     */
    @ServiceActivator(inputChannel = "udpHandle2")
    public void udpMessageHandle2(String message) throws Exception {
        logger.info("UDP2:" + message);
    }

}

下面是使用SpringBoot整合Netty实现UDP服务端的代码示例: 首先,在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>io.netty</groupId> <artifactId>netty-transport-native-epoll</artifactId> <version>4.1.63.Final</version> <classifier>linux-x86_64</classifier> <scope>provided</scope> </dependency> <dependency> <groupId>io.netty</groupId> <artifactId>netty-all</artifactId> <version>4.1.63.Final</version> </dependency> ``` 接下来,创建一个UDP服务器类,如下所示: ```java import io.netty.bootstrap.Bootstrap; import io.netty.channel.*; import io.netty.channel.nio.NioEventLoopGroup; import io.netty.channel.socket.DatagramPacket; import io.netty.channel.socket.nio.NioDatagramChannel; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; @Component public class UdpServer { @Value("${udp.port}") private int port; public void start() throws Exception { EventLoopGroup group = new NioEventLoopGroup(); try { Bootstrap bootstrap = new Bootstrap(); bootstrap.group(group) .channel(NioDatagramChannel.class) .option(ChannelOption.SO_BROADCAST, true) .handler(new ChannelInitializer<Channel>() { @Override protected void initChannel(Channel ch) throws Exception { ChannelPipeline pipeline = ch.pipeline(); pipeline.addLast(new UdpServerHandler()); } }); ChannelFuture future = bootstrap.bind(port).sync(); future.channel().closeFuture().await(); } finally { group.shutdownGracefully(); } } } ``` 然后,创建一个UDP服务器处理程序类,如下所示: ```java import io.netty.channel.ChannelHandlerContext; import io.netty.channel.SimpleChannelInboundHandler; import io.netty.channel.socket.DatagramPacket; public class UdpServerHandler extends SimpleChannelInboundHandler<DatagramPacket> { @Override protected void channelRead0(ChannelHandlerContext ctx, DatagramPacket packet) throws Exception { // 处理接收到的UDP数据包 String message = packet.content().toString(CharsetUtil.UTF_8); // 在这里进行业务处理 System.out.println("接收到UDP消息:" + message); } } ``` 最后,在Spring Boot的启动类中添加以下代码: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.CommandLineRunner; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class Application implements CommandLineRunner { @Autowired private UdpServer udpServer; public static void main(String[] args) { SpringApplication.run(Application.class, args); } @Override public void run(String... args) throws Exception { udpServer.start(); } } ``` 现在,你可以在配置文件中指定UDP服务器的端口号(如application.properties或application.yml),然后运行Spring Boot应用程序来启动UDP服务器。 这样就实现了使用SpringBoot整合Netty实现UDP服务端的代码。你可以根据自己的需求进行进一步的业务处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小道士写程序

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

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

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

打赏作者

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

抵扣说明:

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

余额充值