一、协议包(数据对象需要实现序列化接口,可以用于服务端接口、客户端调用服务之用)

/**
*
*/
package com.junge.demo.protocol.model; import java.io.Serializable; /**
* @author Administrator
*
*/
public class User implements Serializable { /**
*
*/
private static final long serialVersionUID = -8967262939434460765L; private Integer userid;
private String username; public Integer getUserid() {
return userid;
} public void setUserid(Integer userid) {
this.userid = userid;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} @Override
public String toString() {
return "User [userid=" + userid + ", username=" + username + "]";
}
}
/**
*
*/
package com.junge.demo.protocol.service; import com.junge.demo.protocol.model.User; /**
* @author Administrator
*
*/
public interface UserService { Integer addUser(User user); void delUser(Integer userid); void modifyUser(User user); User getUserByUserId(Integer userid);
}

二、服务端(需要建立web项目)

/**
*
*/
package com.junge.spring.hessian.service.impl; import com.junge.demo.protocol.model.User;
import com.junge.demo.protocol.service.UserService; /**
* @author Administrator
*
*/
public class UserServiceImpl implements UserService { public Integer addUser(User user) {
System.out.println("addUser:" + user);
return user.getUserid();
} public void delUser(Integer userid) {
System.out.println("delUser,userid=" + userid); } public void modifyUser(User user) {
System.out.println("modifyUser:" + user); } public User getUserByUserId(Integer userid) {
System.out.println("getUserByUserId,userid={}" + userid); User user = new User();
user.setUserid(userid);
user.setUsername("张三");
return user;
} }

web.xml配置

<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" > <web-app>
<display-name>Archetype Created Web Application</display-name>
<servlet>
<servlet-name>CalServiceServlet</servlet-name>
<servlet-class>com.caucho.hessian.server.HessianServlet</servlet-class>
<init-param>
<param-name>home-class</param-name>
<param-value>com.junge.spring.hessian.service.impl.CalServiceImpl</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>CalServiceServlet</servlet-name>
<url-pattern>/calService</url-pattern>
</servlet-mapping> <servlet>
<servlet-name>UserServiceServlet</servlet-name>
<servlet-class>com.caucho.hessian.server.HessianServlet</servlet-class>
<init-param>
<param-name>home-class</param-name>
<param-value>com.junge.spring.hessian.service.impl.UserServiceImpl</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>UserServiceServlet</servlet-name>
<url-pattern>/userService</url-pattern>
</servlet-mapping>
</web-app>

三、客户端

/**
*
*/
package com.junge.demo.hessian; import com.caucho.hessian.client.HessianProxyFactory;
import com.junge.demo.protocol.model.User;
import com.junge.demo.protocol.service.UserService; /**
* @author Administrator
*
*/
public class HessianClient { /**
* @param args
*/
public static void main(String[] args) {
/*
* try { String url = "http://localhost:8080/hessian/calService";
* HessianProxyFactory factory = new HessianProxyFactory();
* factory.setOverloadEnabled(true); CalService basic = (CalService)
* factory.create(CalService.class, url); System.out.println(basic.add(3, 4));
* System.out.println(basic.sub(3, 0)); } catch (Exception e) {
* e.printStackTrace(); }
*/ addUserBatch();
} public static void addUserBatch() { Long btime = System.currentTimeMillis(); String url = "http://localhost:8080/hessian/userService";
HessianProxyFactory factory = new HessianProxyFactory();
factory.setOverloadEnabled(true); try {
UserService basic = (UserService) factory.create(UserService.class, url);
for (int i = 0; i < 5000; i++) { new Thread(new OperUser(basic)).start();
}
} catch (Exception e) {
e.printStackTrace();
} Long etime = System.currentTimeMillis(); System.out.println(etime - btime);
} } class OperUser implements Runnable {
private UserService userService; public OperUser(UserService userService) {
this.userService = userService;
} @Override
public void run() {
// 增加、详情、修改、删除
User user = new User();
user.setUserid(1);
user.setUsername("名字");
userService.addUser(user); User user2 = userService.getUserByUserId(1); userService.modifyUser(user2); userService.delUser(user2.getUserid()); }
}

Hessian 使用例子的更多相关文章

  1. Hessian的使用以及理解

    官网 http://hessian.caucho.com/ Hessian的使用以及理解Hessian版本:3.1.5将包括如下的内容: Hessian的基本使用Hessian的原理Hessian和S ...

  2. 使用Spring进行远程访问与Web服务

    1.1. 简介   Spring为各种远程访问技术的集成提供了整合类.Spring使得开发具有远程访问功能的服务变得相当容易,而这些远程访问服务由普通Spring POJO实现.目前,Spring支持 ...

  3. [Java]Hessian客户端和服务端代码例子

    简要说明:这是一个比较简单的hessian客户端和服务端,主要实现从客户端发送指定的数据量到服务端,然后服务端在将接收到的数据原封不动返回到客户端.设计该hessian客户端和服务端的初衷是为了做一个 ...

  4. java和c#使用hessian通信

    介绍 hessian主页:http://hessian.caucho.com/ 一个简单的例子学习hessian服务:服务端为Java,客户端为C#. 先要准备好C#和Java的第三方类库:http: ...

  5. Java学习之Hessian通信基础

    一.首先先说Hessian是什么?    Hessian:hessian是一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI的功能,相比WebService,Hessian更简 ...

  6. Hessian 初探

    Hessian 是一个序列化协议, 他的优点在于比 Java 原生的对象序列化/反序列化速度更快, 序列化出来以后的数据更小. 序列化协议跟应用层协议无关, 可以将 Hessian 序列化以后的数据放 ...

  7. hessian入门

    hessian简介 Hessian是二进制的web service协议,官方网站提供Java.Flash/Flex.Python.C++..NET C#等实现.Hessian和Axis.XFire都能 ...

  8. WebService另一种轻量级实现—Hessian 学习笔记

    最近和同事聊天,得知他们在使用一种叫做Hessian的WebService实现方式实现远 程方法调用,是轻量级的,不依赖JavaEE容器,同时也是二进制数据格式传输,效率比SOAP的XML方式要高.感 ...

  9. 利用Hessian如何实现Webservice

    利用Hessian如何实现Webservice [大] [中] [小] 发布人:圣才学习网  发布日期:2012-08-18 14:02  共966人浏览 Hessian是 一个轻量级的remotin ...

随机推荐

  1. Calendar打印日历

    package com.example.demo; import org.junit.Test; import org.junit.runner.RunWith; import org.springf ...

  2. 机器学习算法中的准确率(Precision)、召回率(Recall)、F值(F-Measure)

    摘要: 数据挖掘.机器学习和推荐系统中的评测指标—准确率(Precision).召回率(Recall).F值(F-Measure)简介. 引言: 在机器学习.数据挖掘.推荐系统完成建模之后,需要对模型 ...

  3. android toolbar效果

    layout下的layout_main.xml: <?xml version="1.0" encoding="utf-8"?> <Relati ...

  4. java数据类型关系及关系

    java中有常见的基本数据类型和引用数据类型,基本数据类型为四类八种如下 整数型(byte,short,int,long) 浮点型(float,double) 字符型(char) 布尔型(boolea ...

  5. grep -A -B -C 显示抓取的前后几行参数

    我经常用grep找东西,比如用户名和密码.大部分站点和用户名和密码都是在一样的,方便grep查找.有时,为了文本好看,我会放在多行.比如 wikipedia多个语言版本上有多个账号,就放在wikipe ...

  6. spring学习1

    1.<context:property-placeholder/> :用于从外部属性文件中获取Bean的配置 <context:property-placeholder locati ...

  7. 目标检测框架py-faster-rcnn修改anchor_box

    众所周知,anchor_box控制了回归框的大小,我们有时候检测的是大物体或小物体时,需要调整回归框的大小的时候,得改一下anchor_box.基于rgb公开的py-faster-rcnn修改anch ...

  8. php获取微信的openid

    https://www.cnblogs.com/wxfallstar/p/6826886.html https://www.cnblogs.com/liangxiblog/p/5909432.html

  9. TXLSReadWriteII5 单元格读写

    unit Main; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, ...

  10. [Ting's笔记Day4]将Ruby on Rails项目部署到Heroku

    今天想笔记的是把自己写的Ruby on Rails项目部署(Deploy)到Heroku! Heroku是Salesforce公司旗下的云端服务商,支持多种程序语言像是Ruby,PHP,Python等 ...