diff --git a/jsowell-netty/src/main/java/com/jsowell/netty/decoder/StartAndLengthFieldFrameDecoder.java b/jsowell-netty/src/main/java/com/jsowell/netty/decoder/StartAndLengthFieldFrameDecoder.java index d7e6cdc7f..783957618 100644 --- a/jsowell-netty/src/main/java/com/jsowell/netty/decoder/StartAndLengthFieldFrameDecoder.java +++ b/jsowell-netty/src/main/java/com/jsowell/netty/decoder/StartAndLengthFieldFrameDecoder.java @@ -14,11 +14,11 @@ public class StartAndLengthFieldFrameDecoder extends ByteToMessageDecoder { private static final int HEADER_LENGTH_68 = 1; // 68 包头的长度 // 起始标志 - private int HEAD_DATA; + // private int HEAD_DATA; - public StartAndLengthFieldFrameDecoder(int HEAD_DATA) { - this.HEAD_DATA = HEAD_DATA; - } + // public StartAndLengthFieldFrameDecoder(int HEAD_DATA) { + // this.HEAD_DATA = HEAD_DATA; + // } /** *
@@ -26,62 +26,62 @@ public class StartAndLengthFieldFrameDecoder extends ByteToMessageDecoder {
 	 * 表示数据的长度contentLength,int类型,占据1个字节.
 	 * 
*/ - public final int BASE_LENGTH = 1 + 1; + // public final int BASE_LENGTH = 1 + 1; // @Override - protected void decode2(ChannelHandlerContext ctx, ByteBuf buffer, List out) throws Exception { - // 可读长度必须大于基本长度 - if (buffer.readableBytes() <= BASE_LENGTH) { - log.warn("可读字节数:{}小于基础长度:{}", buffer.readableBytes(), BASE_LENGTH); - return; - } - - // 记录包头开始的index - int beginReader; - - while (true) { - // 获取包头开始的index - beginReader = buffer.readerIndex(); - // log.info("包头开始的index:{}", beginReader); - // 标记包头开始的index - buffer.markReaderIndex(); - // 读到了协议的开始标志,结束while循环 - if (buffer.getUnsignedByte(beginReader) == HEAD_DATA) { - // log.info("读到了协议的开始标志,结束while循环 byte:{}, HEAD_DATA:{}", buffer.getUnsignedByte(beginReader), HEAD_DATA); - break; - } - - // 未读到包头,略过一个字节 - // 每次略过,一个字节,去读取,包头信息的开始标记 - buffer.resetReaderIndex(); - buffer.readByte(); - - // 当略过,一个字节之后, - // 数据包的长度,又变得不满足 - // 此时,应该结束。等待后面的数据到达 - if (buffer.readableBytes() < BASE_LENGTH) { - log.debug("数据包的长度不满足 readableBytes:{}, BASE_LENGTH:{}", buffer.readableBytes(), BASE_LENGTH); - return; - } - } - - // 消息的长度 - int length = buffer.getUnsignedByte(beginReader + 1); - // 判断请求数据包数据是否到齐 - if (buffer.readableBytes() < length + 4) { - // log.info("请求数据包数据没有到齐,还原读指针 readableBytes:{}, 消息的长度:{}", buffer.readableBytes(), length); - // 还原读指针 - buffer.readerIndex(beginReader); - return; - } - - // 读取data数据 - byte[] data = new byte[length + 4]; - buffer.readBytes(data); - ByteBuf frame = buffer.retainedSlice(beginReader, length + 4); - buffer.readerIndex(beginReader + length + 4); - out.add(frame); - } + // protected void decode2(ChannelHandlerContext ctx, ByteBuf buffer, List out) throws Exception { + // // 可读长度必须大于基本长度 + // if (buffer.readableBytes() <= BASE_LENGTH) { + // log.warn("可读字节数:{}小于基础长度:{}", buffer.readableBytes(), BASE_LENGTH); + // return; + // } + // + // // 记录包头开始的index + // int beginReader; + // + // while (true) { + // // 获取包头开始的index + // beginReader = buffer.readerIndex(); + // // log.info("包头开始的index:{}", beginReader); + // // 标记包头开始的index + // buffer.markReaderIndex(); + // // 读到了协议的开始标志,结束while循环 + // if (buffer.getUnsignedByte(beginReader) == HEAD_DATA) { + // // log.info("读到了协议的开始标志,结束while循环 byte:{}, HEAD_DATA:{}", buffer.getUnsignedByte(beginReader), HEAD_DATA); + // break; + // } + // + // // 未读到包头,略过一个字节 + // // 每次略过,一个字节,去读取,包头信息的开始标记 + // buffer.resetReaderIndex(); + // buffer.readByte(); + // + // // 当略过,一个字节之后, + // // 数据包的长度,又变得不满足 + // // 此时,应该结束。等待后面的数据到达 + // if (buffer.readableBytes() < BASE_LENGTH) { + // log.debug("数据包的长度不满足 readableBytes:{}, BASE_LENGTH:{}", buffer.readableBytes(), BASE_LENGTH); + // return; + // } + // } + // + // // 消息的长度 + // int length = buffer.getUnsignedByte(beginReader + 1); + // // 判断请求数据包数据是否到齐 + // if (buffer.readableBytes() < length + 4) { + // // log.info("请求数据包数据没有到齐,还原读指针 readableBytes:{}, 消息的长度:{}", buffer.readableBytes(), length); + // // 还原读指针 + // buffer.readerIndex(beginReader); + // return; + // } + // + // // 读取data数据 + // byte[] data = new byte[length + 4]; + // buffer.readBytes(data); + // ByteBuf frame = buffer.retainedSlice(beginReader, length + 4); + // buffer.readerIndex(beginReader + length + 4); + // out.add(frame); + // } protected void decode(ChannelHandlerContext ctx, ByteBuf buffer, List out) throws Exception { // 记录包头开始的index @@ -97,7 +97,12 @@ public class StartAndLengthFieldFrameDecoder extends ByteToMessageDecoder { buffer.markReaderIndex(); // 读到了协议的开始标志,结束while循环 - if (buffer.getUnsignedByte(beginReader) == HEAD_DATA) { + // if (buffer.getUnsignedByte(beginReader) == HEAD_DATA) { + // break; + // } + + // 读到了协议的开始标志,结束while循环 + if (isStartOfDnyHeader(buffer, beginReader) || isStartOf68Header(buffer, beginReader)) { break; } @@ -132,6 +137,23 @@ public class StartAndLengthFieldFrameDecoder extends ByteToMessageDecoder { buffer.resetReaderIndex(); } + private boolean isStartOfDnyHeader(ByteBuf buffer, int beginReader) { + if (buffer.readableBytes() >= HEADER_LENGTH_DNY) { + byte[] headerBytes = new byte[HEADER_LENGTH_DNY]; + buffer.getBytes(beginReader, headerBytes, 0, HEADER_LENGTH_DNY); + String header = new String(headerBytes, StandardCharsets.UTF_8); + return "DNY".equals(header); + } + return false; + } + + private boolean isStartOf68Header(ByteBuf buffer, int beginReader) { + if (buffer.readableBytes() >= HEADER_LENGTH_68) { + return buffer.getUnsignedByte(beginReader) == 0x68; + } + return false; + } + private void decode68Message(ByteBuf buffer, List out, int beginReader) { if (buffer.readableBytes() < HEADER_LENGTH_68 + 1) { buffer.readerIndex(beginReader); diff --git a/jsowell-netty/src/main/java/com/jsowell/netty/server/NettyServerManager.java b/jsowell-netty/src/main/java/com/jsowell/netty/server/NettyServerManager.java new file mode 100644 index 000000000..0c050ba84 --- /dev/null +++ b/jsowell-netty/src/main/java/com/jsowell/netty/server/NettyServerManager.java @@ -0,0 +1,98 @@ +package com.jsowell.netty.server; + +import com.jsowell.common.constant.Constants; +import com.jsowell.netty.server.yunkuaichong.NettyServerChannelInitializer; +import io.netty.bootstrap.ServerBootstrap; +import io.netty.channel.ChannelFuture; +import io.netty.channel.ChannelOption; +import io.netty.channel.EventLoopGroup; +import io.netty.channel.nio.NioEventLoopGroup; +import io.netty.channel.socket.nio.NioServerSocketChannel; +import io.netty.handler.logging.LogLevel; +import io.netty.handler.logging.LoggingHandler; +import lombok.extern.slf4j.Slf4j; +import org.springframework.boot.CommandLineRunner; +import org.springframework.stereotype.Component; + +import javax.annotation.Resource; +import java.net.InetSocketAddress; + +@Slf4j +@Component +public class NettyServerManager implements CommandLineRunner { + + @Resource + private NettyServerChannelInitializer nettyServerChannelInitializer; + + @Override + public void run(String... args) throws Exception { + startNettyServer(Constants.SOCKET_IP, 9011); + startElectricBikeNettyServer(Constants.SOCKET_IP, 9012); + } + + public void startNettyServer(String host, int port) { + new Thread(() -> { + EventLoopGroup bossGroup = new NioEventLoopGroup(1); + EventLoopGroup workerGroup = new NioEventLoopGroup(); + + try { + ServerBootstrap bootstrap = new ServerBootstrap() + .group(bossGroup, workerGroup) + .channel(NioServerSocketChannel.class) + .handler(new LoggingHandler(LogLevel.DEBUG)) + .option(ChannelOption.SO_BACKLOG, 128) + .option(ChannelOption.SO_REUSEADDR, true) + .childOption(ChannelOption.SO_KEEPALIVE, true) + .childOption(ChannelOption.SO_REUSEADDR, true) + .childHandler(nettyServerChannelInitializer) + .localAddress(new InetSocketAddress(host, port)); + + ChannelFuture future = bootstrap.bind(port).sync(); + if (future.isSuccess()) { + log.info("NettyServer启动成功, 开始监听端口:{}", port); + } else { + log.error("NettyServer启动失败", future.cause()); + } + + future.channel().closeFuture().sync(); + } catch (Exception e) { + log.error("NettyServer.start error", e); + bossGroup.shutdownGracefully(); + workerGroup.shutdownGracefully(); + } + }).start(); + } + + public void startElectricBikeNettyServer(String host, int port) { + new Thread(() -> { + EventLoopGroup bossGroup = new NioEventLoopGroup(1); + EventLoopGroup workerGroup = new NioEventLoopGroup(); + + try { + ServerBootstrap bootstrap = new ServerBootstrap() + .group(bossGroup, workerGroup) + .channel(NioServerSocketChannel.class) + .handler(new LoggingHandler(LogLevel.DEBUG)) + .option(ChannelOption.SO_BACKLOG, 128) + .option(ChannelOption.SO_REUSEADDR, true) + .childOption(ChannelOption.SO_KEEPALIVE, true) + .childOption(ChannelOption.SO_REUSEADDR, true) + .childHandler(nettyServerChannelInitializer) + .localAddress(new InetSocketAddress(host, port)); + + ChannelFuture future = bootstrap.bind(port).sync(); + if (future.isSuccess()) { + log.info("ElectricBikeNettyServer启动成功, 开始监听端口:{}", port); + } else { + log.error("ElectricBikeNettyServer启动失败", future.cause()); + } + + future.channel().closeFuture().sync(); + } catch (Exception e) { + log.error("ElectricBikeNettyServer.start error", e); + bossGroup.shutdownGracefully(); + workerGroup.shutdownGracefully(); + } + }).start(); + } +} diff --git a/jsowell-netty/src/main/java/com/jsowell/netty/server/mqtt/MqttSever.java b/jsowell-netty/src/main/java/com/jsowell/netty/server/mqtt/MqttSever.java index 09649c12d..c2970de0b 100644 --- a/jsowell-netty/src/main/java/com/jsowell/netty/server/mqtt/MqttSever.java +++ b/jsowell-netty/src/main/java/com/jsowell/netty/server/mqtt/MqttSever.java @@ -20,7 +20,7 @@ import java.net.InetSocketAddress; @Slf4j @Component -@Order(5) +@Order(7) public class MqttSever implements CommandLineRunner { @Override diff --git a/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServer.java b/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServer.java index 4ff2a2e5e..d1eb8d88b 100644 --- a/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServer.java +++ b/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServer.java @@ -16,8 +16,9 @@ import javax.annotation.Resource; import java.net.InetSocketAddress; @Slf4j -@Component -@Order(2) +@Deprecated +// @Component +// @Order(3) public class NettyServer implements CommandLineRunner { @Resource private NettyServerChannelInitializer nettyServerChannelInitializer; diff --git a/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerChannelInitializer.java b/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerChannelInitializer.java index 8551a6229..b343fde1b 100644 --- a/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerChannelInitializer.java +++ b/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerChannelInitializer.java @@ -21,7 +21,7 @@ public class NettyServerChannelInitializer extends ChannelInitializer>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 InitializeAdapayConfig order 1 <<<<<<<<<<<<<"); /* 单商户 */ @@ -47,6 +46,7 @@ public class InitializeAdapayConfig implements CommandLineRunner { 目前有jsowell和xixiao */ multiMerchant(); + log.info(">>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 InitializeAdapayConfig order 2 <<<<<<<<<<<<<"); } /** diff --git a/jsowell-pile/src/main/java/com/jsowell/alipay/config/AliPayConfig.java b/jsowell-pile/src/main/java/com/jsowell/alipay/config/AliPayConfig.java index 968c0a227..b9c1b22d2 100644 --- a/jsowell-pile/src/main/java/com/jsowell/alipay/config/AliPayConfig.java +++ b/jsowell-pile/src/main/java/com/jsowell/alipay/config/AliPayConfig.java @@ -11,7 +11,7 @@ import org.springframework.stereotype.Component; @Slf4j @Component -@Order(2) +@Order(4) public class AliPayConfig implements CommandLineRunner { @Value("${alipay.gatewayHost}") private String gatewayHost; @@ -33,7 +33,6 @@ public class AliPayConfig implements CommandLineRunner { @Override public void run(String... args) throws Exception { - log.info(">>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 AliPayConfig order 2 <<<<<<<<<<<<<"); // 设置参数(全局只需设置一次) Config config = new Config(); config.protocol = Constants.HTTPS; @@ -57,5 +56,6 @@ public class AliPayConfig implements CommandLineRunner { // 可设置AES密钥,调用AES加解密相关接口时需要(可选) config.encryptKey = encryptKey; Factory.setOptions(config); + log.info(">>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 AliPayConfig order 4 <<<<<<<<<<<<<"); } } \ No newline at end of file diff --git a/jsowell-pile/src/main/java/com/jsowell/wxpay/config/WechatPayConfig.java b/jsowell-pile/src/main/java/com/jsowell/wxpay/config/WechatPayConfig.java index 797075a5b..dd0d2391f 100644 --- a/jsowell-pile/src/main/java/com/jsowell/wxpay/config/WechatPayConfig.java +++ b/jsowell-pile/src/main/java/com/jsowell/wxpay/config/WechatPayConfig.java @@ -3,13 +3,15 @@ package com.jsowell.wxpay.config; import com.jsowell.wxpay.common.WeChatPayParameter; import com.jsowell.wxpay.utils.WechatPayUtils; +import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.CommandLineRunner; import org.springframework.core.annotation.Order; import org.springframework.stereotype.Component; -@Order(3) +@Slf4j @Component +@Order(5) public class WechatPayConfig implements CommandLineRunner { /** * 公众号appid @@ -78,7 +80,6 @@ public class WechatPayConfig implements CommandLineRunner { @Override public void run(String... args) throws Exception { - System.out.println(">>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 WechatPayConfig order 3 <<<<<<<<<<<<<"); //微信支付 WeChatPayParameter.mchId = wechatMchId; WeChatPayParameter.appId = wechatAppId; @@ -94,5 +95,6 @@ public class WechatPayConfig implements CommandLineRunner { WeChatPayParameter.mchSerialNo = mchSerialNo; //获取平台证书 WeChatPayParameter.certificateMap = WechatPayUtils.refreshCertificate(); + log.info(">>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 WechatPayConfig order 5 <<<<<<<<<<<<<"); } }