XML-RPC-예

XML-RPC를 시연하기 위해 Java를 사용하여 XML-RPC 메시지를 처리하는 서버를 만들고 해당 서버에서 프로 시저를 호출하는 Java 클라이언트를 만들 것입니다.

대화의 Java 쪽에서는 Apache XML 프로젝트의 Apache XML-RPC를 사용합니다. http://xml.apache.org/xmlrpc/

모든 .jar 파일을 적절한 경로에 넣고 JAVA를 사용하여 하나의 클라이언트와 하나의 작은 XML-RPC 서버를 만듭니다.

XML-RPC 클라이언트

sum 함수 라는 함수를 호출하는 XML-RPC 클라이언트를 작성해 보겠습니다 . 이 함수는 두 개의 매개 변수를 취하고 그 합계를 반환합니다.

import java.util.*;
import org.apache.xmlrpc.*;

public class JavaClient {
   public static void main (String [] args) {
   
      try {
         XmlRpcClient client = new XmlRpcClient("http://localhost/RPC2"); 
         Vector params = new Vector();
         
         params.addElement(new Integer(17));
         params.addElement(new Integer(13));

         Object result = server.execute("sample.sum", params);

         int sum = ((Integer) result).intValue();
         System.out.println("The sum is: "+ sum);

      } catch (Exception exception) {
         System.err.println("JavaClient: " + exception);
      }
   }
}

위의 예제 클라이언트에서 어떤 일이 발생했는지 살펴 보겠습니다.

  • Java 패키지 org.apache.xmlrpc에는 XML-RPC Java 클라이언트 및 XML-RPC 서버 (예 : XmlRpcClient) 용 클래스가 포함되어 있습니다.

  • 패키지 java.util은 Vector 클래스에 필요합니다.

  • server.execute (...) 함수 는 서버에 요청을 보냅니다. 프로 시저 sum (17,13)은 마치 로컬 프로 시저 인 것처럼 서버에서 호출됩니다. 프로 시저 호출의 반환 값은 항상 Object입니다.

  • 여기서 "sample"은 서버에 정의 된 핸들러를 나타냅니다.

  • 프로 시저 호출의 모든 매개 변수는 항상 Vector에 수집됩니다.

  • XmlRpcClient 클래스는 서버 컴퓨터의 "웹 주소"다음에 / RPC2를 지정하여 구성됩니다.

    • localhost-로컬 시스템을 의미합니다.

    • localhost 대신 IP 번호를 지정할 수 있습니다 (예 : 194.80.215.219).

    • xyz.dyndns.org와 같은 도메인 이름을 지정할 수 있습니다.

    • 도메인 이름과 함께 포트 번호를 xyz.dyndns.org:8080으로 지정할 수 있습니다. 기본 포트는 80입니다.

  • 원격 프로 시저 호출의 결과는 항상 Object이며 적절한 유형으로 캐스트되어야합니다.

  • 문제가 발생하면 (연결 없음 등) 예외가 발생하고 catch 문을 사용하여 포착해야 합니다.

위의 호출로 인해 클라이언트는 다음 메시지를 서버에 보냅니다. 이것은 내부적 으로 server.execute (...)에 의해 처리되며 당신은 그것과 아무 관련이 없습니다.

<?xml version="1.0" encoding="ISO-8859-1"?>
<methodCall>
   <methodName>sample.sum</methodName>
   <params>
      <param>
         <value><int>17</int></value>
      </param>
		 
      <param>
         <value><int>13</int></value>
      </param>
   </params>
</methodCall>

XML-RPC 서버

다음은 Java로 작성된 XML-RPC 서버의 소스 코드입니다. org.apache.xmlrpc. * 에서 사용할 수있는 내장 클래스를 사용 합니다.

import org.apache.xmlrpc.*;

public class JavaServer { 

   public Integer sum(int x, int y){
      return new Integer(x+y);
   }

   public static void main (String [] args){
   
      try {

         System.out.println("Attempting to start XML-RPC Server...");
         
         WebServer server = new WebServer(80);
         server.addHandler("sample", new JavaServer());
         server.start();
         
         System.out.println("Started successfully.");
         System.out.println("Accepting requests. (Halt program to stop.)");
         
      } catch (Exception exception){
         System.err.println("JavaServer: " + exception);
      }
   }
}

위의 예제 서버에서 수행 한 작업을 살펴 ​​보겠습니다.

  • org.apache.xmlrpc 패키지에는 XML-RPC 서버 구현을위한 WebServer 클래스가 포함되어 있습니다.

  • 원격으로 호출 되는 프로 시저 합계 는 클래스의 공용 메서드로 구현됩니다.

  • 그런 다음 동일한 서버 클래스의 인스턴스가 클라이언트가 액세스 할 수있는 핸들러와 연결됩니다.

  • 서버는 포트 번호 (여기서는 80)로 초기화됩니다.

  • 문제가 발생하면 예외가 발생하고 catch 문을 사용하여 잡아야 합니다.

주어진 예제 클라이언트에서 언급 된 호출에 대해 서버는 다음 응답을 클라이언트에 다시 보냅니다.

<?xml version="1.0" encoding="ISO-8859-1"?>
<methodResponse>
   <params>
      <param>
         <value><int>30</int></value>
      </param>
   </params>
</methodResponse>

이제 서버가 준비되었으므로 다음과 같이 프롬프트에서 컴파일하고 실행하십시오.

C:\ora\xmlrpc\java>java JavaServer
Attempting to start XML-RPC Server...
Started successfully.
Accepting requests. (Halt program to stop.)

이제 기능을 테스트하려면 다음과 같이이 서버를 호출하십시오.

C:\ora\xmlrpc\java>java JavaClient
30