当前位置:   article > 正文

分布式服务架构学习(六):实现自己的序列化工具引擎(五)-序列化Hessian实现_hessian golang

hessian golang

Hession是一个支持跨语言传输的二进制序列化协议,相对于Java默认的序列化机制,Hessian具有更好的性能与易用性,而且支持多种不同的语言。其中,AbstractSerializerFactory、AbstractHessianOutput、AbstractSerializer、AbstractHessianInput、AbstractDeserializer是Hessian实现序列化和反序列化的核心类。

示例代码如下:

  1. package ares.remoting.framework.serialization.serializer.impl;
  2. import ares.remoting.framework.serialization.serializer.ISerializer;
  3. import com.caucho.hessian.io.HessianInput;
  4. import com.caucho.hessian.io.HessianOutput;
  5. import java.io.ByteArrayInputStream;
  6. import java.io.ByteArrayOutputStream;
  7. /**
  8. * @author fuss created on 18/7/23.
  9. * @version $Id$
  10. */
  11. public class HessianSerializer implements ISerializer {
  12. public byte[] serialize(Object obj) {
  13. if (obj == null)
  14. throw new NullPointerException();
  15. try {
  16. ByteArrayOutputStream os = new ByteArrayOutputStream();
  17. HessianOutput ho = new HessianOutput(os);
  18. ho.writeObject(obj);
  19. return os.toByteArray();
  20. } catch (Exception e) {
  21. throw new RuntimeException(e);
  22. }
  23. }
  24. public <T> T deserialize(byte[] data, Class<T> clazz) {
  25. if (data == null)
  26. throw new NullPointerException();
  27. try {
  28. ByteArrayInputStream is = new ByteArrayInputStream(data);
  29. HessianInput hi = new HessianInput(is);
  30. return (T) hi.readObject();
  31. } catch (Exception e) {
  32. throw new RuntimeException(e);
  33. }
  34. }
  35. }

Hessian Maven依赖配置如下:

  1. <!-- hession -->
  2. <dependency>
  3. <groupId>com.caucho</groupId>
  4. <artifactId>hessian</artifactId>
  5. <version>4.0.38</version>
  6. </dependency>

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Guff_9hys/article/detail/1011994
推荐阅读
相关标签
  

闽ICP备14008679号