jetty与hessian结合

Hessian是由caucho提供的一个基于binary-RPC实现的远程通讯library,支持多种语言,包括c++,java,c#等,还支持flash/flex     Jetty 是一个开源的servlet容器,它是作为一个可以嵌入到其他的Java代码中的servlet容器而设计的。     通过结合jetty和hessian结合,就可以通过一个普通的java工程来提供远程通信服务,而不需要建立一个web工程     首先编写接口和服务类

public interface Hello {

String sayHello(String name);
}
import com.caucho.hessian.server.HessianServlet;

/**
 * @author cjj
*
*/
public class HelloImpl extends HessianServlet implements Hello {

/**

*

*/

private static final long serialVersionUID = 1464625224364842441L;

@Override

public String sayHello(String name) {

return"hello:"+name;

}

}

HelloImpl 继承 HessianServlet 服务启动类:

import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.servlet.ServletContextHandler;
import org.eclipse.jetty.servlet.ServletHolder;
import org.prime.jerryhessian.service.HelloImpl;

/**
 * @author cjj
*
*/
public class OneServletContext {

public static void main(String[] args) throws Exception {

Server server = new Server(8080);

ServletContextHandler context = new ServletContextHandler(

ServletContextHandler.SESSIONS);

context.setContextPath("/");

server.setHandler(context);

context.addServlet(new ServletHolder(new HelloImpl()),"/hello");

server.start();

server.join();

}

}

客户端代码为:

import java.net.MalformedURLException;

import org.prime.jerryhessian.service.Hello;

import com.caucho.hessian.client.HessianProxyFactory;

/**
 * @author cjj
*
*/
public class HelloTest {

/**

 * @param args

 * @throws MalformedURLException 

*/

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

HessianProxyFactory factory = new HessianProxyFactory();

Hello hello = (Hello) factory.create(Hello.class,

"http://127.0.0.1:8080/hello");

System.out.println(hello.sayHello("cjj"));

}

}

运行结果:

时间: 2024-12-14 08:33:29

jetty与hessian结合的相关文章

Hessian 初探

Hessian 是一个序列化协议, 他的优点在于比 Java 原生的对象序列化/反序列化速度更快, 序列化出来以后的数据更小. 序列化协议跟应用层协议无关, 可以将 Hessian 序列化以后的数据放在 HTTP Body 里, 也可以放在 DUBBO 里, 或者直接用 Socket 传输 下面是一个使用 Jetty 跟 Hessian 实现的 Hessian web service 的例子 pom.xml <project xmlns="http://maven.apache.org/P

maven + hessian 简单例子

项目结构如下: pom.xml 内容: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"&g

dubbo_实现Hessian的远程调用协议

1.优点 连接个数:多连接 连接方式:短连接 传输协议:HTTP 传输方式:同步传输 序列化:Hessian二进制序列化 适用范围:传入传出参数数据包较大,提供者比消费者个数多,提供者压力较大,可传文件. 适用场景:页面传输,文件传输,或与原生hessian服务互操作 约束: 参数及返回值需实现Serializable接口 参数及返回值不能自定义实现List, Map, Number, Date, Calendar等接口,只能用JDK自带的实现,因为hessian会做特殊处理,自定义实现类中的属

Hessian入门案例

1.1.  Hessian简介 Hessian:hessian是一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI的功能,相比WebService,Hessian更简单.快捷.采用的是二进制RPC协议,因为采用了二进制协议,所以它很适合于发送二进制数据,Hessian主要作面向对象的消息通信. 1.2.  开发步骤 1.2.1.   导入jar包 去官网下载http://hessian.caucho.com/ 1.2.2.   编写远程接口 Ihello.java pac

SPRING注解发布RMI/HTTPInvoker/Hessian/Burlap服务

最近做系统重构,计划将多个系统的公共部分抽取出来作为一项公共服务,为以后项目维护和横向扩展奠定基础. 常用的服务发布方式有RMI / HTTPInvoker / Hessian / Burlap,关于这几类java远程服务的性能比较和优缺点大家可参考:http://www.cnblogs.com/jifeng/archive/2011/07/20/2111183.html ,本文着重讲解怎样使用自定的注解标签,结合SPRING将服务方便的发布出去. 一. Maven配置 <dependency>

配置jetty 远程调试

该调试不支持hessian 接口调用 1.配置远程jetty 服务器的 bin/jetty.sh JAVA_OPTIONS+=("-Xdebug -Xrunjdwp:server=y,transport=dt_socket,address=10000,suspend=n") 2.配置eclipse 远程Debug

Dubbo服务 上传文件解决方案以及Hessian协议

? 协议支持 Dubbo支持多种协议,如下所示: Dubbo协议 Hessian协议 HTTP协议 RMI协议 WebService协议 Thrift协议 Memcached协议 Redis协议 在通信过程中,不同的服务等级一般对应着不同的服务质量,那么选择合适的协议便是一件非常重要的事情.你可以根据你应用的创建来选择.例如,使用RMI协议,一般会受到防火墙的限制,所以对于外部与内部进行通信的场景,就不要使用RMI协议,而是基于HTTP协议或者Hessian协议. dubbo服务不支持File文

Jetty使用

目标:在Linux以及Windows下面配置应用: 之前使用过smartfox,安装的时候弹出一个浏览器,一路next,印象很深刻.只是记得他是使用Jetty.最近做的项目也是需要进行配置:过往都是使用SWT进行制作:但是此次有一个网页版的监控程序,我的想法就是连带着配置程序一起坐到这个监控程序中. Jetty是内嵌式的Servlet容器:启动一个执行html的很简单,但是启动一个Jsp的工程,则需要多写几步,左后是启动默认浏览器并跳转到指定的页面: ????public static void

Maven部署Jetty服务器pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion&