Hessian是一个轻量级的RPC框架,它基于HTTP协议传输,使用Hessian二进制序列化,对于数据包比较大的情况比较友好。但是它的参数和返回值都需要实现Serializable接口。Hessian的最大优势在于跨平台,多语言支持和比较合理的性能,目前Hessian支持,如Java、Flash/Flex、Python、C++、.NET C#、D、Erlang、PHP、Rubby、Objective C。
对于Hessian类型的接口如何进行调用呢?小编尝试使用Postman、Httpie都无法调用,于是尝试使用python进行调用,但这种类型的接口和标准Http协议的接口有所区别,使用requests发起请求也无法实现。查找一些资料,都说使用 hessianlib.py ,但版本好久未更新,也不支持python3,见下图: 后来才发现原来python3支持hessian需要安装 python-hessian 扩展包,源码 https://github.com/bgilmore/mustaine,直接使用 pip install python-hessian 安装。现在给以下的一个实例:
这是 LmWorkerTaskServcie.java 接口类:
/**
*
* @param
* @return
*/
import java.util.List;
import apollo.erp.base.domain.LmWorkerTask;
/**
*
* @author zt
* @version 1.0
* @date 2018-9-25 下午2:31:00
* 说明:
*
*/
public interface LmWorkerTaskService {
/**
*
* @param barcode
* @param lmTaskJson
* @return
* @throws Exception
*/
public String insertLmWorkerTask(String barcode,String lmTaskJson) ;
}
接下来便是利用python调用上面的接口了,问题就解决了。注意(多数博客就是调用方法不同, __call__可以查看底层源码)
import json
from pyhessian.client import HessianProxy
def run():
url = "http://192.168.133.129:20880/apollo-erp-remote/lmWorkerTaskService"
params = {
'barcode': 'A502170661032-5-1',
'lmTaskJson': json.dumps({
"barcode": "A502170661032-5-1",
"unitcode": "YB",
"userCode": "211573",
"operateTime": "2018-09-28 11:12:39:667",
"type": "in"
})
}
service = HessianProxy(url)
response = service.__call__(method='insertLmWorkerTask', args=(params['barcode'], params['lmTaskJson']))
return response
if __name__ == '__main__':
print(run())