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编写的服务,是不是很简单??

代码下载

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

reg183

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

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

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

打赏作者

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

抵扣说明:

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

余额充值