Hprose轻松实现远程过程调用(RPC)

项目中发现了Hprose,通过这个开源组件可以轻松通过Web应用的形式发布WebService,实现远程过程调用,真的是非常强大!!!看了几篇博文,也自己动手实现了一下,现总结过程如下:

一、Hprose的Maven依赖

<dependency>
    <groupId>org.hprose</groupId>
    <artifactId>hprose-java</artifactId>
    <version>2.0.32</version>
</dependency>

二、编写服务端

首先创建一个Web项目,编写一个POJO的Service类,这个类将对外提供服务:

package com.lin.pr;

public class Service {
    public String sayHello(String name) {
        return "Hello," + name;
    }
}

然后继承HproseServlet,编写一个定制的Servlet,从而对外暴露服务接口:

package com.lin.pr;

import hprose.common.HproseMethods;
import hprose.server.HproseServlet;

@WebServlet(urlPatterns = {"/hprose/service"})
public class ServicePublish extends HproseServlet{

    @Override
    protected void setGlobalMethods(HproseMethods methods) {
        super.setGlobalMethods(methods);
        //发布sayHello方法
        Service service = new Service();
        methods.addMethod("sayHello", service);
    }
    
}

入口方法要做适当修改

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.ServletComponentScan;

@ServletComponentScan //启动器启动时,扫描本目录以及子目录带有的webservlet注解的
@SpringBootApplication
public class HproseApplication {

	public static void main(String[] args) {
		SpringApplication.run(HproseApplication.class, args);
	}

}

至此,服务端已经编写完毕!

三、编写客户端

客户端只需要创建一个简单的Maven项目,引入hprose依赖的jar包即可。

可通过invoke和编写Service接口两种形式调用远程服务,具体看代码即可:

package org.lin.userhprose;

import hprose.client.HproseHttpClient;

/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
        HproseHttpClient client = new HproseHttpClient();
        client.useService("http://localhost:8080/hprose/service");
        
        //通过接口调用
        IService service = client.useService(IService.class);
        String content = service.sayHello("Jack");
        System.out.println("rpc调用,返回:" + content);
        
        
        
//        try {
//            //通过invoke调用
//            String content = client.invoke("sayHello", new Object[]{"Jack"}, String.class);
//            System.out.println("rpc调用,返回:" + content);
//        } catch (Throwable e) {
//            e.printStackTrace();
//        }
    }
}

package org.lin.userhprose;

public interface IService {
    public String sayHello(String name);
}

至此,客户端编写完毕!

测试结果

rpc调用,返回:Hello,Jack

四、总结

可以看到,客户端可以通过接口调用服务,而服务端甚至不需要有此接口。同时Hprose是跨语言的,其他语言通过相应的类库就可调用我们使用Java编写的服务,是不是很简单??

代码下载

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,你的问题是关于 Hprose for Java 服务器的吗?那么,让我来为你解答。Hprose是一种跨语言的RPC协议,提供了多种语言的实现方式,包括Java、PHP、Python、JavaScript等。在Java中,我们可以使用Hprose for Java实现服务器端的开发。 要使用Hprose for Java,首先需要在项目中引入相应的依赖。在Maven项目中,可以在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>com.github.hsiafan</groupId> <artifactId>hprose-java</artifactId> <version>3.0.8</version> </dependency> ``` 在使用Hprose for Java时,需要定义一个接口,并在接口上添加@HproseService注解,表示这是一个Hprose服务。接着,我们可以在接口中定义需要暴露给客户端调用的方法,方法的参数和返回值可以是任意类型。例如: ``` @HproseService public interface MyService { String sayHello(String name); } ``` 在实现类中,我们需要实现接口中定义的方法,并启动Hprose服务器,将实现类注册为服务提供者。例如: ``` public class MyServiceImpl implements MyService { @Override public String sayHello(String name) { return "Hello, " + name + "!"; } public static void main(String[] args) throws IOException { MyService service = new MyServiceImpl(); HproseTcpServer server = new HproseTcpServer("tcp://0.0.0.0:8080"); server.add(service, MyService.class); server.start(); } } ``` 以上代码创建了一个TCP协议的Hprose服务器,监听8080端口,将MyServiceImpl实例注册为服务提供者,并暴露了一个名为sayHello的方法。 客户端可以使用Hprose for Java提供的客户端类来调用服务端的方法。例如: ``` public class MyClient { public static void main(String[] args) throws IOException { HproseTcpClient client = new HproseTcpClient("tcp://localhost:8080"); MyService service = client.useService(MyService.class); String result = service.sayHello("world"); System.out.println(result); } } ``` 以上代码创建了一个TCP协议的Hprose客户端,连接到本地的8080端口,并调用了服务端的sayHello方法。 这就是Hprose for Java服务器端的基本使用方法。希望能够对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

reg183

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值