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 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())

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章