Hessian序列化与反序列化对象

Hessian序列化与反序列化对象

package com.lius.DistributedProject.RPC.rpc_hessian;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.Serializable;

import com.caucho.hessian.io.HessianInput;
import com.caucho.hessian.io.HessianOutput;

/**
 * Hessian 序列化与反序列化
 * @author lius
 *
 */
public class seriableHessian implements Serializable{

	
	//序列化
	private byte[] seriableHessianFun(Object obj) throws IOException {
		ByteArrayOutputStream baos = new ByteArrayOutputStream();
		HessianOutput ho = new HessianOutput(baos);
		ho.writeObject(obj);
		byte[] resultByte = baos.toByteArray();
		return resultByte;
	}
	
	//反序列化
	private Object reverseHessianFun(byte[] byteArray) throws IOException {
		ByteArrayInputStream bais = new ByteArrayInputStream(byteArray);
		HessianInput hi = new HessianInput(bais);
		Object resultObject = hi.readObject();
		return resultObject;
	}
	
	//apply
	public static void main(String[] args) throws IOException {
		new seriableHessian().start();
	}
	
	
	private void start() throws IOException {
		//实例化对象
		student stu = new student("tom", 19);
		stu.print();
		//序列化对象
		byte[] byteArray = seriableHessianFun(stu);
		//反序列化对象
		student obj = (student) reverseHessianFun(byteArray);
		obj.print();
	}
	
	
	class student implements Serializable{
		
		private String name;
		private int age;
		public student(String name, int age) {
			super();
			this.name = name;
			this.age = age;
		}
		@Override
		public String toString() {
			return "student [name=" + name + ", age=" + age + "]";
		}
		
		public void print() {
			System.out.println(toString());
		}
	}
	
	 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值