PHPRPC,它的商业版本是Hprose。这里仅记录其使用方法。其它相关内容可自行搜索。

对于开源的东西,建议大家看看其源码。

1、需要引入的jar包:phprpc_spring.jar,http://pan.baidu.com/s/1eQhbUwU

2、web.xml中添加的内容:

 <!-- phprpc -->
<servlet>
<servlet-name>phprpc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:phprpc-servlet.xml</param-value>
<!-- <param-value>WEB-INF/classes/phprpc-servlet.xml</param-value> -->
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>phprpc</servlet-name>
<url-pattern>/phprpc/*</url-pattern>
</servlet-mapping>

3、新建phprpc-servlet.xml,内容如下:

 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd"> <!-- PHPRPC配置 -->
<!--appservice中要注入的内容,需要set和get方法。同时此处用property配置好。不讲详细了 -->
<bean id="phprpcControllerImpl" class="com.XXXX.biz.controller.PhprpcControllerImpl">
<property name="phprpcService" ref="phprpcService"></property>
</bean> <bean name="/phpRpcService.htm" class="org.phprpc.spring.remoting.PHPRPC_Exporter">
<property name="service" ref="phprpcControllerImpl" />
<property name="serviceInterface" value="com.XXXX.biz.controller.PhprpcController" />
</bean>
</beans>

2和3决定了可以使用 项目路径例如:http://localhost:8080/project/phprpc/phpRpcService.htm 访问接口。

4、分别新建以下内容

接口:PhprpcController.java

public interface PhprpcController {

    public String test(String type,Object firstorders,Object secondorders,Object thirdorders);
}

接口实现类:PhprpcControllerImpl.java

@Controller
public class PhprpcControllerImpl extends BaseController implements PhprpcController{ @Autowired
private PhprpcService phprpcService; public PhprpcService getPhprpcService() {
return phprpcService;
} public void setPhprpcService(PhprpcService phprpcService) {
this.phprpcService = phprpcService;
} public String test(String type,Object firstorders,Object secondorders,Object thirdorders) {
log.info("执行rpc。。。 type:"+type+" firstorders:"+firstorders+" secondorders:"+secondorders+" thirdorders"+thirdorders);
log.info("参数类型。。。 type:"+type+" firstorders:"+firstorders.getClass().getName()+
" secondorders:"+secondorders.getClass().getName()+" thirdorders"+thirdorders.getClass().getName());
String msg = "Hello PHPRPC!";
return msg;
}
}

--------------------分界线--------------------------上面是构建phpRpc,下面是使用----------------------------------------分界线-------------------------------------------

5、在知道了类似 【http://localhost:8080/project/phprpc/phpRpcService.htm】这样的地址后,我们可以在另外一个程序中这样使用该rpc提供的方法。

以下代码和前面4段没有什么关系,仅随意展示了其一些使用方法,方法名【pushOrderData】并无实际意义,请勿自行关联,以防被误导。

A、invoke的参数:第一个为方法名,第二个为传入方法的参数(对象数组,必须按照顺序存放参数)
B、org.phprpc.util.Cast 是一个PHPRPC封装好的数据类型转换工具类。
public class PhpRpcDemo {
public static void main(String[] args) throws UnsupportedEncodingException {
String url3 = "http://localhost:8080/XXXXXX/phprpc/phpRpcService.htm";
PHPRPC_Client client = new PHPRPC_Client(url3);
//PhprpcClient.setEncryptMode(3);
//1获取公钥
Object tempRet = client.invoke("getRsaPulbicKey", new Object[] {}); String tempJsonStr = Cast.toString(tempRet); System.out.println(tempJsonStr); //回调
//test1(client); //Map 和 List 类型
//test2(client); //String类型
String jsons2 = "[{'id':'872'}]";
Object ret = client.invoke("pushOrderData", new Object[] {"1",null,jsons2,null,null});
String s = Cast.toString(ret);
System.out.println(s); */ //也可以以 callback形式调用.
/* client.invoke("say", new Object[] {}, new PHPRPC_Callback() {
public void handler(String result, Object[] args) {
System.out.println("handler:");
System.out.println(result);
System.out.println("args:"+args[0]);
System.out.println();
}
});*/
} private static void test2(PHPRPC_Client client) {
    
AssocArray ret1 = (AssocArray)client.invoke("pushOrderData", new Object[] {"1","","",""});
Map m = ret1.toHashMap();
//Cast.toString(null);
System.out.println(m);
} private static void test1(PHPRPC_Client client) {
Object[] d = new Object[4];
client.invoke("pushOrderData", d,new PHPRPC_Callback() {
public void handler(String result, Object[] args) {
System.out.println("handler:");
System.out.println(result);
System.out.println("args:"+args[0]);
System.out.println();
}
}); System.out.println(d);
}
}

spring集成PHPRPC及使用的更多相关文章

  1. 从零开始学 Java - Spring 集成 Memcached 缓存配置(二)

    Memcached 客户端选择 上一篇文章 从零开始学 Java - Spring 集成 Memcached 缓存配置(一)中我们讲到这篇要谈客户端的选择,在 Java 中一般常用的有三个: Memc ...

  2. 从零开始学 Java - Spring 集成 ActiveMQ 配置(一)

    你家小区下面有没有快递柜 近两年来,我们收取快递的方式好像变了,变得我们其实并不需要见到快递小哥也能拿到自己的快递了.对,我说的就是类似快递柜.菜鸟驿站这类的代收点的出现,把我们原来快递小哥必须拿着快 ...

  3. 【转】Dubbo使用例子并且和Spring集成使用

    一.编写客户端和服务器端共用接口类1.登录接口类public interface LoginService {    public User login(String name, String psw ...

  4. 从零开始学 Java - Spring 集成 Memcached 缓存配置(一)

    硬盘和内存的作用是什么 硬盘的作用毫无疑问我们大家都清楚,不就是用来存储数据文件的么?如照片.视频.各种文档或等等,肯定也有你喜欢的某位岛国老师的动作片,这个时候无论我们电脑是否关机重启它们永远在那里 ...

  5. axis2+spring集成

    转载自:http://www.cnblogs.com/linjiqin/archive/2011/07/05/2098316.html 1.新建一个web project项目,最终工程目录如下: 注意 ...

  6. rabbitMQ第五篇:Spring集成RabbitMQ

    前面几篇讲解了如何使用rabbitMq,这一篇主要讲解spring集成rabbitmq. 首先引入配置文件org.springframework.amqp,如下 <dependency> ...

  7. 从零开始学 Java - Spring 集成 ActiveMQ 配置(二)

    从上一篇开始说起 上一篇从零开始学 Java - Spring 集成 ActiveMQ 配置(一)文章中讲了我关于消息队列的思考过程,现在这一篇会讲到 ActivMQ 与 Spring 框架的整合配置 ...

  8. spring集成常用技术的配置

    使用spring集成其他技术,最基本的配置都是模板化的,比如配置视图模板引擎.数据库连接池.orm框架.缓存服务.邮件服务.rpc调用等,以spring的xml配置为例,我将这些配置过程整理出来,并不 ...

  9. Activiti工作流学习(三)Activiti工作流与spring集成

    一.前言 前面Activiti工作流的学习,说明了Activiti的基本应用,在我们开发中可以根据实际的业务参考Activiti的API去更好的理解以及巩固.我们实际的开发中我们基本上都使用sprin ...

随机推荐

  1. c/c++相关面试准备笔记1

    在c++程序中调用被C编译器编译后的函数,为什么要加extern  “C”? C++语言支持函数重载,C语言不支持函数重载.函数被C++编译后在库中的名字与C语言的不同.C++提供了C连接交换指定符号 ...

  2. Centos7下zabbix部署(三)自定义监控项

    引言 在前面的博客中我们介绍了zabbix自带的模板,并且完成了我们的一些比较常用的监控,现在我们如果想要监控我们磁盘的IO,这时候zabbix并没有给我们提供这么一个模板,所以我们需要自己来创建一个 ...

  3. ef code first commad

    PM> enable-migrations 已在项目“EasyWeChat.Data”中启用迁移.若要覆盖现有迁移配置,请使用 -Force 参数. PM> add-migration 位 ...

  4. ActiveMQ StartUp

    从http://activemq.apache.org/activemq-5132-release.html 下载 解压 从apache-activemq-5.13.2\bin\win64\wrapp ...

  5. J.U.C并发框架源码阅读(五)Semaphore

    基于版本jdk1.7.0_80 java.util.concurrent.Semaphore 代码如下 /* * ORACLE PROPRIETARY/CONFIDENTIAL. Use is sub ...

  6. Java IO 学习(五)跟踪三个文件IO方法的调用链

    假设我们想要用Java读取一个二进制文件,有好几种方式,本文会选取其中比较典型的三种方式进行详细分析 0. 准备工作 安装openjdk-1.8.0.141(普通的jdk中涉及IO的很多代码是闭源的, ...

  7. Python的功能模块[0] -> wmi -> 获取 Windows 内部信息

    wmi模块 / wmi Module WMI (Windows Management Instrumentation) 模块可用于获取 Windows 内部信息.该模块需要 win32com 的支持, ...

  8. uva11107(后缀数组)

    uva11107 题意 输入 n 个 DNA 序列,求出长度最大的字符串,使得它在超过一半的 DNA 序列中连续出现.如果有多解,按字典序输出. 分析 论文 后缀数组经典题.加深几个关键数组的印象. ...

  9. 集群/分布式/微服务/SOA 转

    https://www.cnblogs.com/Java3y/p/9479410.html 二.集群/分布式/微服务/SOA是什么? 像我这种技术小白,看到这些词(集群/分布式/微服务/SOA)的时候 ...

  10. SOAP很2的问题

    小弟说实话不很懂这方面的东西,但上头要求比较一下这两种方式的优劣,欢迎大家赐教啊!“按照一定的网络传输协议,通过符合 FTP/TCP/IP等协议的数据报或者以SOAP的方式传送到接口服务器.”这是出处 ...