windows下的eclipse程序打jar包在linux下運行(xml-rpc初試)

由於項目需要在windows下面寫的程序在linux下運行。


測試xml-rpc的運用

XML-RPC只是一個協議,這裏主要介紹一個實現了 XML-RPC協議的java 開源的框架apache的 XML-RPC 實現。

第一步:去官方下載XML-RPC框架,地址是:[url=http://ws.apache.org/xmlrpc/index.html]Apache XML-RPC [/url]

第二步: XML-RPC分爲客戶端跟服務端。

創建客戶端:


import java.net.MalformedURLException;
import java.net.URL;
import org.apache.xmlrpc.XmlRpcException;
import org.apache.xmlrpc.client.XmlRpcClient;
import org.apache.xmlrpc.client.XmlRpcClientConfigImpl;
import org.apache.xmlrpc.client.XmlRpcHttpClientConfig;
import org.apache.xmlrpc.client.XmlRpcLiteHttpTransportFactory;
import org.apache.xmlrpc.client.XmlRpcLocalTransportFactory;
import org.apache.xmlrpc.client.XmlRpcSunHttpTransportFactory;

public class HelloClient {
public static void main(String[] arg)throws MalformedURLException, XmlRpcException {
//XmlRpcHttpClientConfig clientConfig = XmlRpcHttpClientConfig();
XmlRpcClientConfigImpl clientConfig = new XmlRpcClientConfigImpl();
clientConfig.setServerURL(new URL("http://192.168.19.2:7777/xmlrpc"));

XmlRpcClient client = new XmlRpcClient();
client.setTransportFactory(new XmlRpcSunHttpTransportFactory(client));

client.setConfig(clientConfig);
Object[] params = new Object[] { "wly"};
String result = (String) client.execute("hello.sayHello", params);
System.out.println("Response from server is: " + result);
}
}



Handler:


public class HelloHandler {
public String sayHello(String name){
return "hello11:"+name;
}
}


創建服務端:


import java.io.IOException;
import org.apache.xmlrpc.XmlRpcException;
import org.apache.xmlrpc.server.PropertyHandlerMapping;
import org.apache.xmlrpc.server.XmlRpcServer;
import org.apache.xmlrpc.server.XmlRpcServerConfigImpl;
import org.apache.xmlrpc.webserver.WebServer;

public class HelloServer {
public static final int PORT = 7777;

public static void main(String[] arg)throws XmlRpcException,IOException{
System.out.println("Start rpc Server Now...");
WebServer webServer = new WebServer(PORT
XmlRpcServer xmlRpcServer = webServer.getXmlRpcServer();
PropertyHandlerMapping propertyHandlerMapping = new PropertyHandlerMapping();
propertyHandlerMapping.addHandler("hello", HelloHandler.class);
xmlRpcServer.setHandlerMapping(propertyHandlerMapping);
XmlRpcServerConfigImpl serverConfig = (XmlRpcServerConfigImpl)xmlRpcServer.getConfig();
serverConfig.setEnabledForExceptions(true);
serverConfig.setContentLengthOptional(false);
webServer.start();
System.out.println("Registered HelloHandler to \"hello\"");
System.out.println("Now Accepting Requests ...");
}
}



這是一個最簡單的hello代碼。

下面要去測試遠程的調用,然後抓包下來看。

把項目打包放到linux(IP:192.168.19.2)上面運行server端,在windows上面運行client,然後通過tcpdump抓包。

第一:首先把項目打包,在eclipse中在項目名上面右擊,選擇Export,然後出現

[img]http://dl.iteye.com/upload/attachment/184230/11c207ae-c422-3577-af92-fc34da0ca98f.jpg[/img]

選擇jar包,導出。

這個就生成了工程的一個jar包。我的命名爲server.jar
,再加上xml-RPC原來的幾個包,commons-logging-1.1.jar;ws-commons-util-1.0.2.jar;xmlrpc-client-3.1.2.jar;xmlrpc-common-3.1.2.jar;xmlrpc-server-3.1.2.jar.

在linux的那臺機子上的某個目錄下建個文件夾,我的是/opt/test,把上個幾個.jar包拷貝到test文件夾中。這樣後再寫一個shell文件來運行server端。

shell的寫法。

#! /bin/sh

/opt/jdk/1.6/bin/java -cp "/opt/test/commons-logging-1.1.jar:/opt/test/server.jar:/opt/test/ws-commons-util-1.0.2.jar:/opt/test/xmlrpc-client-3.1.2.jar:/opt/test/xmlrpc-common-3.1.2.jar:/opt/test/xmlrpc-server-3.1.2.jar" org.apache.xmlrpc.test.HelloServer

保存後命名test.sh,chmod 777 test.sh (賦權限)
然後運行./test.sh,這時server端就已經運行起來。

通過tcpdump -i ethx -s 0 host 192.168.19.2 port 7777 -w /tmp/ws.cap進行抓包,保存到/tmp/ws.cap 然後用ethereal工具打開。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章