因为公司的项目远程调用采用的是hessian,故抽时间了解了下hessian,自己也写了一个应用实例,以便加深对hessian的理解。

Hessian是一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI的功能。 相比WebService,Hessian更简单、快捷。采用的是二进制RPC协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。

在进行基于Hessian的项目开发时,应当注意以下几点:

JAVA服务器端必须具备以下几点:

·包含Hessian的jar包

·设计一个接口,用来给客户端调用

·实现该接口的功能

·配置web.xml,配好相应的servlet

·对象必须实现Serializable 接口

·对于复杂对象可以使用Map的方法传递

客户端必须具备以下几点:

·java客户端包含Hessian.jar的包。

·具有和服务器端结构一样的接口。包括命名空间都最好一样

·利用HessianProxyFactory调用远程接口。

以下是一个关于hessian应用的示例程序。

示例背景:

由于本人所在公司正在编码直播室方面的项目,故以下源码中用LiveRoom.java类为直播室的类。User.java类为用户类。直播室和用户之间为一对多的关系。即一个直播室里面有多个用户。本示例将实现对直播室的增删改查功能

我们先写服务端

服务端,即提供服务的一端(废话,呵呵),需要定义接口,并提供接口实现。

首先,定义两个类LiveRoom和User,并且两个类都要实现Serializable 接口

package org.study.hessian.domain;

import java.io.Serializable;

import java.util.ArrayList;

import java.util.List;

public class LiveRoom implements Serializable,Comparable<LiveRoom>{

private static final long serialVersionUID = -3219121209937741843L;

private int roomId;

private String roomName;

public List<User> users = new ArrayList<User>();

public LiveRoom(int roomId, String roomName) {

super();

this.roomId = roomId;

this.roomName = roomName;

}

public LiveRoom() {

super();

}

public int getRoomId() {

return roomId;

}

public void setRoomId(int roomId) {

this.roomId = roomId;

}

public String getRoomName() {

return roomName;

}

public void setRoomName(String roomName) {

this.roomName = roomName;

}

public int compareTo(LiveRoom o) {

if(this.getRoomId() > o.getRoomId()){

return 1;

}

else if(this.getRoomId() < o.getRoomId()){

return -1;

}

else

{

return 0;

}

}

}

package org.study.hessian.domain;

import java.io.Serializable;

import java.util.Date;

public class User implements Serializable{

private int userId;

private String userName;

private Date birth;

public int getUserId() {

return userId;

}

public void setUserId(int userId) {

this.userId = userId;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

public Date getBirth() {

return birth;

}

public void setBirth(Date birth) {

this.birth = birth;

}

}

然后定义接口

package org.study.hessian.service;

import java.util.List;

import org.study.hessian.domain.LiveRoom;

public interface LiveRoomService {

public abstract void addRoom(LiveRoom room);

public abstract void delRoom(int roomId);

public abstract void updateRoom(LiveRoom room);

public abstract LiveRoom getRoomById(int roomId);

public abstract List<LiveRoom> getAllRoom();

}

接口的实现

package org.study.hessian.service.impl;

import java.util.ArrayList;

import java.util.Collection;

import java.util.Collections;

import java.util.HashMap;

import java.util.Iterator;

import java.util.List;

import java.util.Map;

import org.study.hessian.domain.LiveRoom;

import org.study.hessian.service.LiveRoomService;

public class LiveRoomServiceImpl implements LiveRoomService {

public Map<Integer, LiveRoom> roomMap = new HashMap<Integer, LiveRoom>();

public void addRoom(LiveRoom room) {

roomMap.put(room.getRoomId(), room);

}

public void delRoom(int roomId) {

roomMap.remove(roomId);

}

public List<LiveRoom> getAllRoom() {

List<LiveRoom> list = new ArrayList<LiveRoom>();

Collection<LiveRoom> coll = roomMap.values();

Iterator<LiveRoom> it = coll.iterator();

while(it.hasNext()){

LiveRoom room = it.next();

list.add(room);

}

Collections.sort(list);

return list;

}

public LiveRoom getRoomById(int roomId) {

return roomMap.get(roomId);

}

public void updateRoom(LiveRoom room) {

roomMap.remove(room.getRoomId());

roomMap.put(room.getRoomId(), room);

}

}

配置web.xml,配好相应的servlet

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://java.sun.com/xml/ns/javaee

http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

<welcome-file-list>

<welcome-file>index.jsp</welcome-file>

</welcome-file-list>

<servlet>

<servlet-name>liveRoom</servlet-name>

<servlet-class>

com.caucho.hessian.server.HessianServlet

</servlet-class>

<init-param>

<!-- home-class也可以写为service-class -->

<param-name>home-class</param-name>

<!-- 服务器对接口的现实,供客户端调用 -->

<param-value>

org.study.hessian.service.impl.LiveRoomServiceImpl

</param-value>

</init-param>

<init-param>

<!--home-api也可以写为api-class  -->

<param-name>home-api</param-name>

<!-- 客户端接口 -->

<param-value>org.study.hessian.service.LiveRoomService</param-value>

</init-param>

</servlet>

<servlet-mapping>

<servlet-name>liveRoom</servlet-name>

<url-pattern>/liveRoom</url-pattern>

</servlet-mapping>

</web-app>

至此,服务端的代码就写完了。

接着,我们写客户端

注:客户端需要服务端定义的两个类和定义的接口(不需要接口的实现)

客户端的调用代码如下:

package org.study.hessian;

import java.net.MalformedURLException;

import java.util.ArrayList;

import java.util.Date;

import java.util.List;

import org.study.hessian.api.LiveRoomService;

import org.study.hessian.domain.LiveRoom;

import org.study.hessian.domain.User;

import org.study.hessian.utils.PropertyFileUtil;

import com.caucho.hessian.client.HessianProxyFactory;

public class Test {

public static void main(String[] args) throws MalformedURLException,

ClassNotFoundException {

// 远程调用地址

String url="http://localhost:8080/HessianServer/liveRoom";

System.out.println(url);

HessianProxyFactory factory = new HessianProxyFactory();

LiveRoomService liveRoomService = (LiveRoomService) factory.create(

LiveRoomService.class, url);

for (int i = 1; i < 10; i++) {

LiveRoom room = new LiveRoom();

room.setRoomId(i);

room.setRoomName("liveRoom" + i);

List<User> list = new ArrayList<User>();

for (int j = 1; j < 5; j++) {

User user = new User();

user.setUserId(j);

user.setUserName("xiongyuewen" + j);

user.setBirth(new Date());

list.add(user);

}

room.users = list;

liveRoomService.addRoom(room);

}

liveRoomService.delRoom(3);

LiveRoom room = new LiveRoom();

room.setRoomId(4);

room.setRoomName("wanglili");

room.users = null;

liveRoomService.updateRoom(room);

List<LiveRoom> listRooms = liveRoomService.getAllRoom();

if (listRooms == null) {

throw new RuntimeException("listRooms is null");

}

for (LiveRoom lr : listRooms) {

System.out.println(lr.getRoomName());

List<User> users = lr.users;

if (users == null) {

continue;

}

for (User user : users) {

System.out.println(user.getUserName() + " " + user.getBirth());

}

}

}

}

hessian应用示例的更多相关文章

  1. Hessian探究(一)Hessian入门示例

    一.hessian的maven信息: [html] view plain copy print? <dependency> <groupId>com.caucho</gr ...

  2. hessian原理解析一(客户端分析)

    hessian 是一款开源的二进制远程通讯协议,使用简单方法提供了RMI功能,主要用于面向对象的消息通信. 优点:跨平台.多语言支持.使用简单 缺点:传递复杂对象性能会下降,不适合安全性高的应用 一 ...

  3. Hessian探究(一)Hessian与springMVC结合

    上一篇博客Hessian探究(一)Hessian入门示例我们初步简单的介绍了一下Hessian的使用入门示例,我们是通过Servlet来暴露Hessian的对外服务的,接下来我们介绍一下通过Sprin ...

  4. Hessian探究(一)Hessian与Spring结合

    上一篇博客Hessian探究(一)Hessian入门示例我们初步简单的介绍了一下Hessian的使用入门示例,由于Spring现在使用的实在是太广泛了,接下来我们介绍一下Hessian和Spring一 ...

  5. Ruby入门--Linux/Windows下的安装、代码开发及Rails实战

    Ruby入门--Linux/Windows下的安装.代码开发及Rails实战 http://www.linuxidc.com/Linux/2014-04/100242.htm Ubuntu 13.04 ...

  6. Hessian示例:Java和C#通信

    一个简单的利用Hessian在Java和C#之间通信的例子,服务端为Java,客户端为C#. 资源下载 先要准备好C#和Java的第三方类库:http://hessian.caucho.com/ Hs ...

  7. Hessian服务端和客户端示例

    一.服务端 1.创建web项目,建立客户端调用的hessian接口和实现类. 接口: package com.ymx.hessian.service; import com.ymx.hessian.s ...

  8. 【RPC】使用Hessian构建RPC的简单示例

    服务接口和实现 public interface HelloService { // 服务方法 String sayHello(String name); } public class HelloSe ...

  9. Hessian 接口使用示例总结

    一.使用hessian接口准备 首先,hessian接口的使用,必须要准备hessian接口的jar包,本文使用的jar包如下:hessian-4.0.7.jar; Hessian接口的使用一般是在两 ...

随机推荐

  1. net Core 入门实战

    Asp.net Core 入门实战   Asp.Net Core 是开源,跨平台,模块化,快速而简单的Web框架. Asp.net Core官网的一个源码合集,方便一次性Clone 目录 快速入门 安 ...

  2. centos下svnadmin的部署过程

    1.    安装SVN #yum –y install subversion 2.    安装openjdk #yum –y list java* #yum –y install java-1.8.0 ...

  3. IO(Properties、序列化流、打印流、CommonsIO)

    第1章 Properties类 1.1 Properties类介绍 Properties 类表示了一个持久的属性集.Properties 可保存在流中或从流中加载.属性列表中每个键及其对应值都是一个字 ...

  4. 学JS的书籍

    1.JavaScript DOM 编程艺术 [说明] 这本书最大的特点就是简明易懂,循序渐进,适合初学者,非常容易上手. 计划:三天读完 读书总结:待写 2.Javascript权威指南 特点是权威. ...

  5. 行框基线位置确定(line box 基线)

    在设置vertical-align属性(只有inline元素有效,对inline-block和block元素无效)时有一个属性值:baseline,那么这个基线是什么,怎么确定. 这个基线就是其所在行 ...

  6. Java中的多线程详解

    如果对什么是线程.什么是进程仍存有疑惑,请先Google之,因为这两个概念不在本文的范围之内. 用多线程只有一个目的,那就是更好的利用cpu的资源,因为所有的多线程代码都可以用单线程来实现.说这个话其 ...

  7. Python3+Selenium3+webdriver学习笔记14(等待判断 鼠标事件 )

    !/usr/bin/env python -*- coding:utf-8 -*-'''Selenium3+webdriver学习笔记14(等待判断 鼠标事件 )'''from selenium im ...

  8. Python之时间表示

    Python的time模块中提供了丰富的关于时间操作方法,可以利用这些方法来完成这个需求. time.time() :获取当前时间戳 time.ctime(): 当前时间的字符串形式 time.loc ...

  9. [windows]清除访问共享的用户和密码信息

    方法一: 操作步骤:进入cmd命令界面-->输入:net use(查看列表)-->输入:net use * /delete(清空列表)-->输入:y 回车确认即可. [查看已记录的登 ...

  10. Uva 127 poj 1214 `Accordian'' Patience 纸牌游戏 模拟

    Input Input data to the program specifies the order in which cards are dealt from the pack. The inpu ...