>>分享流行的Java框架以及开源软件,对孙卫琴的《精通Spring》、《Spring Cloud Alibaba微服务开发零基础入门到实操》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 19851 个阅读者 刷新本主题
 * 贴子主题:  Marshalling在Netty中的使用 回复文章 点赞(0)  收藏  
作者:mary    发表时间:2021-06-24 03:45:15     消息  查看  搜索  好友  邮件  复制  引用

1. 引入jar包

  <dependency>

<groupId>org.jboss.marshalling</groupId>

<artifactId>jboss-marshalling</artifactId>

<version>1.4.10.Final</version>

</dependency>

<dependency>

<groupId>org.jboss.marshalling</groupId>

<artifactId>jboss-marshalling-serial</artifactId>

<version>1.4.10.Final</version>

</dependency>

2.编写编码解码程序

public final class MarshallingCodeCFactory {

    /**
     * 创建Jboss Marshalling解码器MarshallingDecoder
     * @return MarshallingDecoder
     */

    public static MarshallingDecoder buildMarshallingDecoder() {
        //首先通过Marshalling工具类的精通方法获取Marshalling实例对象 参数serial标识创建的是java序列化工厂对象。
        final MarshallerFactory marshallerFactory = Marshalling.getProvidedMarshallerFactory("serial");
        //创建了MarshallingConfiguration对象,配置了版本号为5
        final MarshallingConfiguration configuration = new MarshallingConfiguration();
        configuration.setVersion(5);
        //根据marshallerFactory和configuration创建provider
        UnmarshallerProvider provider = new DefaultUnmarshallerProvider(marshallerFactory, configuration);
        //构建Netty的MarshallingDecoder对象,俩个参数分别为provider和单个消息序列化后的最大长度
        MarshallingDecoder decoder = new MarshallingDecoder(provider, 1024 * 1024 * 1);
        return decoder;
    }

    /**
     * 创建Jboss Marshalling编码器MarshallingEncoder
     * @return MarshallingEncoder
     */

    public static MarshallingEncoder buildMarshallingEncoder() {
        final MarshallerFactory marshallerFactory = Marshalling.getProvidedMarshallerFactory("serial");
        final MarshallingConfiguration configuration = new MarshallingConfiguration();
        configuration.setVersion(5);
        MarshallerProvider provider = new DefaultMarshallerProvider(marshallerFactory, configuration);
        //构建Netty的MarshallingEncoder对象,MarshallingEncoder用于实现序列化接口的POJO对象序列化为二进制数组
        MarshallingEncoder encoder = new MarshallingEncoder(provider);
        return encoder;
    }

}

3.使用

socketChannel.pipeline().addLast(MarshallingCodeCFactory.buildMarshallingDecoder());

socketChannel.pipeline().addLast(MarshallingCodeCFactory.buildMarshallingEncoder());

4.注意事项

  要传输的对象必须实现原生的序列化
public class RpcRequest  implements Serializable { }

  ----------------------------
原文链接:https://www.jianshu.com/p/ab9fb15800a5

程序猿的技术大观园:www.javathinker.net



[这个贴子最后由 flybird 在 2021-06-24 11:08:27 重新编辑]
  Java面向对象编程-->泛型
  JavaWeb开发-->JavaWeb应用入门(Ⅰ)
  JSP与Hibernate开发-->映射组成关系
  Java网络编程-->基于MVC和RMI的分布式应用
  精通Spring-->绑定CSS样式
  Vue3开发-->创建综合购物网站应用
  MessagePack反序列化使用示例
  微服务架构集大成者—Spring Cloud简明教程
  Mybatis常见注解有哪些?
  Spring API中JAVA反射—工具类ReflectionUtils
  WebFlux 响应式编程初体验
  重新理解响应式编程
  @Service注解的使用
  在Spring MVC中配置线程池,进行异步请求处理
  Spring Boot、SpringMVC进行i18n国际化支持:使用MessageSou...
  Spring MVC国际化
  SpringMVC Model、ModelMap和ModelAndView的区别和用法
  Spring MVC的国际化
  Spring Cloud构建微服务架构: 消息总线
  聊聊Spring Cloud版本的那些事儿
  Spring Framework 组件注册 之 @Import
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。