在路上

 找回密码
 立即注册
在路上 站点首页 学习 查看内容

使用Java调用Python服务器RPC

2017-2-16 13:16| 发布者: zhangjf| 查看: 848| 评论: 0

摘要: 使用Java调用Python服务器RPC,附带Python建立RPC服务器或客户端的通用库 #先上一个整体的Python代码,它可以作为Python建立RPC服务器或客户端的通用库 #test_rpc.py#coding=utf-8from SimpleXMLRPCServer import Si ...
使用Java调用Python服务器RPC,附带Python建立RPC服务器或客户端的通用库

#先上一个整体的Python代码,它可以作为Python建立RPC服务器或客户端的通用库

  1. #test_rpc.py
  2. #coding=utf-8
  3. from SimpleXMLRPCServer import SimpleXMLRPCServer
  4. from SocketServer import ThreadingMixIn
  5. from xmlrpclib import ServerProxy
  6. import thread
  7. class ThreadXMLRPCServer(ThreadingMixIn, SimpleXMLRPCServer):
  8. pass
  9. class RPCServer():
  10. def __init__(self, ip='127.0.0.1', port='8000'):
  11. self.ip = ip
  12. self.port = int(port)
  13. self.svr = None
  14. def start(self, func_lst):
  15. thread.start_new_thread(self.service, (func_lst, 0,))
  16. def resume_service(self, v1, v2):
  17. self.svr.serve_forever(poll_interval=0.001)
  18. def service(self, func_lst, v1):
  19. self.svr = ThreadXMLRPCServer((self.ip, self.port), allow_none=True)
  20. for func in func_lst:
  21. self.svr.register_function(func)
  22. self.svr.serve_forever(poll_interval=0.001)
  23. def activate(self):
  24. thread.start_new_thread(self.resume_service, (0, 0,))
  25. def shutdown(self):
  26. try:
  27. self.svr.shutdown()
  28. except Exception, e:
  29. print 'rpc_server shutdown:', str(e)
  30. class RPCClient():
  31. def __init__(self, ip='127.0.0.1', port='8000'):
  32. self.svr = ServerProxy('http://'+ip+':'+port+'/', allow_none=True, use_datetime=True)
  33. def get_svr(self):
  34. return self.svr
  35. def get_hello():
  36. return 'hello!'
  37. if __name__ == "__main__":
  38. r = RPCServer('0.0.0.0', '8061')
  39. r.service([get_hello], 0) #这里仅仅载入get_hello函数
复制代码

#启动test_rpc.py待用

  1. python test_rpc.py
复制代码

#下面开始Java,首先下载jar包 ,在 https://archive.apache.org/dist/ws/xmlrpc/binaries/ 找到 apache-xmlrpc-3.1.3-bin.tar.gz 。

#apache-xmlrpc-3.1.3-bin.tar.gz包的API文档 http://ws.apache.org/xmlrpc/apidocs/index.html

#如果使用Eclipse,通过 “右键项目根目录->properties->Java Build Path->Libraries->add External JARs" 导入jar包

commons-logging-1.1.jar

xmlrpc-client-3.1.3.jar

xmlrpc-server-3.1.3.jar

ws-commons-util-1.0.2.jar

xmlrpc-common-3.1.3.jar

  1. import java.net.URL;
  2. import java.net.MalformedURLException;
  3. import org.apache.xmlrpc.XmlRpcException;
  4. import org.apache.xmlrpc.client.XmlRpcClient;
  5. import org.apache.xmlrpc.client.XmlRpcClientConfigImpl;
  6. import org.apache.xmlrpc.client.XmlRpcHttpTransportException;
  7. public class Test {
  8. public static void main(String[] args) throws MalformedURLException,
  9. XmlRpcHttpTransportException {
  10. XmlRpcClientConfigImpl config = new XmlRpcClientConfigImpl();
  11. config.setServerURL(new URL("http://127.0.0.1:8061/RPC2"));
  12. XmlRpcClient client = new XmlRpcClient();
  13. client.setConfig(config);
  14. // 根据不同的python函数形式,构造参数
  15. // 两个整形参数
  16. //Object[] params = new Object[] {new Integer(1), new Integer(2)};
  17. // 单个字符串参数
  18. //Object[] params = new Object[] {new String("HELLO")};
  19. // 无参数
  20. Object[] params = null;
  21. try {
  22. // 返回的结果是字符串类型,强制转换res为String类型
  23. String res = (String) client.execute("get_hello", params);
  24. System.out.println(res);
  25. } catch (XmlRpcException e11) {
  26. e11.printStackTrace();
  27. }
  28. }
  29. }
复制代码


参考:

http://blog.sina.com.cn/s/blog_6de3aa8a0101jmru.html

最新评论

小黑屋|在路上 ( 蜀ICP备15035742号-1 

;

GMT+8, 2025-5-8 16:34

Copyright 2015-2025 djqfx

返回顶部