`
wly719
  • 浏览: 290074 次
  • 性别: Icon_minigender_2
  • 来自: 杭州
社区版块
存档分类
最新评论

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

阅读更多
由于项目需要在windows下面写的程序在linux下运行。


测试xml-rpc的运用

  XML-RPC只是一个协议,这里主要介绍一个实现了 XML-RPC协议的java 开源的框架apache的 XML-RPC 实现。

   第一步:去官方下载XML-RPC框架,地址是:Apache XML-RPC

   第二步: 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,然后出现



选择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工具打开。







  • 大小: 55.9 KB
分享到:
评论

相关推荐

    Eclipse怎么打jar包(可运行的jar包)

    Eclipse怎么打jar包(可运行的jar包) 教你一步一步,学会怎么打jar包,内含详细图文教程。

    Eclipse打包Java应用程序及在Linux系统上的部署运行[归纳].pdf

    Eclipse打包Java应用程序及在Linux系统上的部署运行 本文主要介绍了使用Eclipse将Java应用程序打包成JAR文件,并在Linux系统上部署和运行的步骤。下面是知识点的详细说明: 一、Eclipse打包Java应用程序 1. 在...

    Eclipse打包成JAR包读取外部JAR包和外部配置文件

    本文将详细介绍如何在Eclipse中将项目打包成JAR文件,并确保能正确引用外部JAR包和读取外部配置文件。 首先,我们来看如何打包项目为JAR。在Eclipse中,选择`Export` -> `Java` -> `Runnable JAR file`。在弹出的...

    xercesImpl.jar,xml-apis.jar

    在这种情况下,将`xercesImpl.jar`和`xml-apis.jar`添加到项目的类路径中,可以替代系统默认的解析器,从而解决这个错误。通常,这可以通过以下几种方式实现: 1. **在Eclipse或IntelliJ IDEA等集成开发环境中**:...

    eclipse-java-2023-09-R-linux-gtk-x86-64.tar.gz

    标题中的“eclipse-java-2023-09-R-linux-gtk-x86-64.tar.gz”指的是Eclipse IDE for Java开发者的特定版本,适用于2023年9月发布(R代表Release),针对Linux操作系统,且是64位(x86_64)系统的版本。这个文件采用...

    hadoop-eclipse-plugin-2.10.0.jar

    Eclipse集成Hadoop2.10.0的插件,使用`ant`对hadoop的jar包进行打包并...- `hadoop2x-eclipse-plugin-master/src/contrib/eclipse-plugin/build.xml` 开源源地址: https://github.com/winghc/hadoop2x-eclipse-plugin

    mysql-connector-java Linux下MySQL的JDBC驱动Jar包

    本篇文章将详细讲解“mysql-connector-java”在Linux下作为MySQL的JDBC驱动Jar包的相关知识点。 1. JDBC简介: JDBC是Java平台上的一个标准接口,它允许Java应用程序通过API与各种类型的数据库进行通信。JDBC提供...

    Eclipse jar打包详解

    6. 将生成的 jar 文件和存放引用包的 lib 文件夹放在同一个目录下,最后点击生成的 jar 文件就可以成功运行了。 Eclipse jar 打包的注意事项 在使用 Eclipse 生成 jar 文件时,需要注意以下几点: * 在 manifest ...

    eclipse-4.7.0-linux.gtk.x86-64.tar.gz

    在Linux环境下,Eclipse提供了一个与Windows或Mac OS相似的开发体验。 压缩包子文件 "eclipse-4.7.0" 暗示解压后会得到一个包含Eclipse IDE所有文件和目录的结构,包括可执行文件、配置文件、帮助文档、库文件等。...

    Eclipse 打可执行JAR包

    本篇文章将详细介绍如何在Eclipse中创建一个可执行的JAR文件,使得你的Java程序可以独立运行。 一、创建可执行JAR包的背景与意义 在Java中,JAR(Java Archive)文件是一种归档格式,用于集合多个类文件、资源文件...

    window下eclipse中运行mapreduce程序所需要的Hadoop全部jar包

    总之,要在Windows下的Eclipse环境中成功运行MapReduce程序,关键在于正确配置Hadoop环境,导入所有必要的jar包,并理解如何设置和提交MapReduce作业。这个过程可能需要一些时间和实践,但一旦配置完成,将为高效...

    axis2相关jar包~eclipse支持插件包

    1、axis2相关jar包如下: axiom-api-1.2.10.jar axiom-dom-1.2.10.jar axiom-impl-1.2.10.jar axis2-adb-1.5.4.jar axis2-adb-codegen-1.5.4.jar axis2-codegen-1.5.4.jar axis2-corba-1.5.4.jar axis2-fastinfoset-...

    jetty-xml-9.4.11.v20180605-API文档-中英对照版.zip

    赠送jar包:jetty-xml-9.4.11.v20180605.jar; 赠送原API文档:jetty-xml-9.4.11.v20180605-javadoc.jar; 赠送源代码:jetty-xml-9.4.11.v20180605-sources.jar; 赠送Maven依赖信息文件:jetty-xml-9.4.11.v...

    eclipse 下各种 jar 包

    mysql_connection、Oraclesql_connection、dom4j、jaxen、dbcp、pool、swt的 eclipse的jar包,已经全部编译在压缩包中,解压后导入 eclipse 即可使用。可以在其他项目直接引用该文件夹下的对应包即可

    QT+eclipse插件qt-eclipse-integration-linux.x86_64-1.6.1 1.6.0等

    对于Windows用户,qt-eclipse-integration-win32-1.6.1.exe是一个可执行文件,用于在Windows环境下安装插件。这个.exe文件是一个标准的Windows安装程序,用户只需双击运行,然后按照安装向导的指示完成安装过程。 ...

    hadoop-eclipse-plugin-2.6.0.jar

    在实际使用中,将`hadoop-eclipse-plugin-2.6.0.jar`文件复制到Eclipse的`dropins`目录下,重启Eclipse后,插件会被自动识别并加载。然后,开发者可以在Eclipse的"New"菜单中找到Hadoop相关的项目模板,开始构建...

    eclipse-linux软件包-包含mapreduce的jar包

    这个"eclipse-linux软件包"特别针对Linux操作系统进行了优化,确保开发者能够在Linux环境下高效地进行开发工作。其中包含了MapReduce的jar包,这意味着它特别适用于进行大数据处理相关的项目。 MapReduce是一种...

    在eclipse当中运行tomcat源代码需要的jar包

    在Eclipse中运行Tomcat源代码,需要一系列的依赖库,包括JAR包,以便能够正确编译、理解和执行Tomcat服务器的相关组件。以下是对给定的文件信息中提到的几个关键JAR包的详细解释: 1. **org.eclipse.jdt.core_3.4.0...

    Eclipse导出Jar包

    * 灵活性:Jar 包可以在不同的环境中运行,例如 Windows、Linux、Mac 等。 * 安全性:Jar 包提供了安全机制,保护用户的代码和数据。 在 Dos 窗口中运行 Jar 包: (5)之后在 Jar 包所在位置,按住 Shift 键,...

    eclipse运行mr插件hadoop-eclipse-plugin-2.6.0.jar

    本文将深入探讨如何使用Eclipse IDE结合hadoop-eclipse-plugin-2.6.0.jar插件,实现在Windows环境下进行远程连接到Hadoop集群,尤其适用于64位操作系统。 首先,我们要理解Hadoop的核心概念。Hadoop是由Apache基金...

Global site tag (gtag.js) - Google Analytics