本文主要是介绍python3调用基于hessian协议的接口(亲测有效),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
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 HessianProxydef 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 responseif __name__ == '__main__':print(run())
这篇关于python3调用基于hessian协议的接口(亲测有效)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!