使用Java客戶端類調用c# WebService和xml rpc server

本文介紹一個非常實用的Java客戶端工具類來調用C# WebServices和apache XML rpc server,這個類的源碼是從網上下載的,我在博客網做項目的時候一直使用這個類來調試C# WebServices和MetaWeblog API。順便在這裏也給大家介紹一下C#如何處理此類發送的xml數據。

使用這個類不用安裝任何第三方工具,因爲采用http的方式發送xml文件,所以你只需要安裝好JDK就可以了。執行此類還可以獲得WebServices或xml rpc server返回的xml字符流,你可以根據返回的xml數據來進行其他程序處理。通過這種方式實現了Java平台和.NET平台的數據交換和WebService調用。

下面是此類的源代碼SOAPClient4XG.java:

/**

* SOAPClient4XG. Read the SOAP envelope file passed as the second

* parameter, pass it to the SOAP endpoint passed as the first parameter, and

* print out the SOAP envelope passed as a response. with help from Michael

* Brennan 03/09/01

*

*

* @author Bob DUCharme

* @version 1.1

* @param SOAPUrl URL of SOAP Endpoint to send request.

* @param xmlFile2Send A file with an XML document of the request.

*

* 5/23/01 revision: SOAPAction added

*/

import java.io.*;

import java.net.*;

public class SOAPClient4XG {

public static void main(String[] args) throws Exception {

if (args.length < 2) { //小于

System.err.println("Usage: java SOAPClient4XG " +

"http://soapURL soapEnvelopefile.xml" +

" [SOAPAction]");

System.err.println("SOAPAction is optional.");

System.exit(1);

}

String SOAPUrl = args[0];

String xmlFile2Send = args[1];

String SOAPAction = "";

if (args.length > 2) //大于

SOAPAction = args[2];

// Create the connection where we're going to send the file.

URL url = new URL(SOAPUrl);

URLConnection connection = url.openConnection();

HttpURLConnection httpConn = (HttpURLConnection) connection;

// Open the input file. After we copy it to a byte array, we can see

// how big it is so that we can set the HTTP Cotent-Length

// property. (See complete e-mail below for more on this.)

FileInputStream fin = new FileInputStream(xmlFile2Send);

ByteArrayOutputStream bout = new ByteArrayOutputStream();

// Copy the SOAP file to the open connection.

copy(fin,bout);

fin.close();

byte[] b = bout.toByteArray();

// Set the appropriate HTTP parameters.

httpConn.setRequestProperty( "Content-Length",

String.valueOf( b.length ) );

httpConn.setRequestProperty("Content-Type","text/xml; charset=utf-8");

httpConn.setRequestProperty("SOAPAction",SOAPAction);

httpConn.setRequestMethod( "POST" );

httpConn.setDoOutput(true);

httpConn.setDoInput(true);

// Everything's set up; send the XML that was read in to b.

OutputStream out = httpConn.getOutputStream();

out.write( b );

out.close();

// Read the response and write it to standard out.

InputStreamReader isr =

new InputStreamReader(httpConn.getInputStream());

BufferedReader in = new BufferedReader(isr);

String inputLine;

while ((inputLine = in.readLine()) != null)

System.out.println(inputLine);

in.close();

}

// copy method from From E.R. Harold's book "Java I/O"

public static void copy(InputStream in, OutputStream out)

throws IOException {

// do not allow other threads to read from the

// input or write to the output while copying is

// taking place

synchronized (in) {

synchronized (out) {

byte[] buffer = new byte[256];

while (true) {

int bytesRead = in.read(buffer);

if (bytesRead == -1) break;

out.write(buffer, 0, bytesRead);

}

}

}

}

}

編譯:javac SOAPClient4XG.java

運行的命令格式: java -classpath . SOAPClient4XG http://localhost/BokeServices/Service1.asmx c:loginReq.xml http://tempuri.org/UserLoginReq,不過先不要運行上面的命令,先介紹一下命令行的意思,http://localhost/BokeServices/Service1.asmx是C# WebService的地址,c:loginReq..xml裏的內容是調用的WebService方法的xml文件, http://tempuri.org是WebService方法的命名空間,一定要有,否則調用失敗,假如你在C# WebServices中使用了方法默認的命名空間的話,就使用http://tempuri.org,否則要與C#中定義的一致,UserLoginReq是C# WebServices的方法名。

 
Oralce 調用Delphi寫DLL去訪問C# WebService的問題
我想從Oracle的存儲過程通過一個外部dll(Delphi編寫)去訪問C#寫的WebService時,出現了“尚未調用 CoInitialize”不知道是怎麽回事,望各位指點一二。1、我在Oracle裏寫了一個函數AddNumber如下:CREATE...查看完整版>>Oralce 調用Delphi寫DLL去訪問C# WebService的問題
 
利用FrontPage使用XML WebService
  XML Web Service  Microsoft? .NET Framework 最令人激動的一點是包含了可擴展標記語言 (XML) Web Service。Web 服務允許應用程序間以基于標准的方式來通信和交換信息。Microsoft 的 Web 服務的實現有許多內在...查看完整版>>利用FrontPage使用XML WebService
 
SQL Server 2005 FOR XML嵌套查詢使用詳解
相比SQL Server 2000提供的FOR XML查詢,SQL Server 2005版本對現有功能增強的基礎上增加了不少新功能,最爲吸引人的功能包括對Xml數據類型支持、使用PATH模式以及嵌套FOR XML查詢支持等,這意味著通過新的FOR XML查...查看完整版>>SQL Server 2005 FOR XML嵌套查詢使用詳解
 
使用Microsoft SQL Server 2000的XML查詢
  由于XML本身的諸多優點,XML技術已被廣泛的使用,目前的好多軟件技術同XML緊密相關,比如微軟的。net 平台對xml提供了強大的支持,提供System.Xml以及其子命名空間下的類型來操作xml.Ado.net通過核心類型DataSet...查看完整版>>使用Microsoft SQL Server 2000的XML查詢
 
使用Microsoft SQL Server 2000的XML查詢
使用Microsoft SQL Server 2000的XML查詢鄭佐 2005-6-28 由于XML本身的諸多優點,XML技術已被廣泛的使用,目前的好多軟件技術同XML緊密相關,比如微軟的.net 平台對xml提供了強大的支持,提供System.Xml以及其子命名...查看完整版>>使用Microsoft SQL Server 2000的XML查詢