출처: http://ko.wikipedia.org/wiki/SOAP

SOAP(Simple Object Access Protocol)은 일반적으로 널리 알려진 HTTP,HTTPS,SMTP등을 사용하여 XML기반의 메시지를 컴퓨터 네트워크 상에서 교환하는 형태의 프로토콜이다. SOAP은 웹 서비스(Web Service)에서 기본적인 메시지를 전달하는 기반이 된다. SOAP에는 몇가지 형태의 메시지 패턴이 있지만, 보통의 경우 원격 프로시져 호출(Remote Procedure Call:RPC) 패턴으로, 네트워크 노드(클라이언트)에서 다른 쪽 노드(서버)쪽으로 메시지를 요청 하고, 서버는 메시지를 즉시 응답하게 된다. SOAP는 XML-RPC와 WDDX에서 envelope/header/body로 이루어진 구조와 전송(transport)와 상호 중립성(interaction neutrality)의 개념을 가져왔다.

SOAP은 XML을 근간으로 헤더와 바디를 조합하는 디자인 패턴으로 설계되어 있다. 「헤더」는 선택사항으로 반복이나 보안 및 트랜젝션을 정보로 하는 메타 정보를 가지고 있다. 「바디」부분은 주요한 정보인 정보를 가지고 있다.



역사
SOAP는 'Simple Object Access Protocol'의 약어를 의미하지만, 버전 1.2 표준 에서 부터는 그 의미가 퇴색되었다.2003년 6월 24일, W3C에서 버전 1.2 권고안이 나왔으며, 서비스 기반 아키텍처(SOA:Service-oriented architecture)와 그 의미가 종종 혼용된다. 그러나, 엄연히 SOAP와 SOA는 다르다. SOAP는 데이브 위너(Deabe Winer),돈 박스(Don Box), 밥 액킨슨(Bob Atkinson) 그리고 모슨 얼 고세인(Mohsen Al-Ghosein)들에 의해 1998년 마이크로소프트(액킨슨과 얼 고세인이 그 당시 일하고 있던)의 후원으로 객체 접근 규약(Object Acess Protocol)로서 최초로 디자인 되었다.SOAP의 표준화 작업은 현재 W3C의 XML protocol Working Group 쪽에서 관리를 하고 있다.



전송 방식 (Transport Method)
SOAP는 인터넷 어플리케이션 계층에 있는 프로토콜을 전송계층의 프로토콜로 사용할 수 있게 만든다. 혹자는 이러한 프로토콜의 의도된 목적과 역할이 맞지 않는 부정이용에 대하여 비판하지만, SOAP의 지지자들은 터널링을 위한 다양한 계층(level)에서 사용되고있는 다른 프로토콜들과 비슷하다고 말하고 있다. SMTP와 HTTP에서 어플리케이션 계층 프로토콜로 트랜스포트 계층의 역할을 대신하는것이 SOAP는 올바른 이용이라 할 수 있으나, HTTP는 오늘날 인터넷 인프라와 매우 잘 동작하여 더 폭넓은 지원을 가능하게 한다. 특히나, HTTP는 방화벽이 작동하는 네트워크 안에서도 문제 없이 작동한다. SOAP는 HTTPS(어플리케이션 계층에서는 HTTP와 동일하나 트랜스포트 계층 아래에서는 암호화됨)에서도 간략하게 또는 상호적으로 사용된다.

이는 WS-I방식으로 Basic Profile 1.1에서 서술된것과 같이 웹서비스의 보안을 제공하고 있다. 이 점은, GIOP/IIOP 혹은 DCOM등과 같은 방화벽에서 쉽게 필터링 당하는 여타의 배포 프로토콜등과의 비교 우위를 점하고 있다. XML은 대다수 회사들과 오픈 소스 개발 진영쪽의 노력에 힘입어 광범위하게 사용되는 메시지 포맷으로써 표준으로 선택되었다. 추가적으로, 광범위하게 무료로 사용한 툴들이 상당하게 포진하고 있는 점은 SOAP-기반 구현으로 옮겨가기 쉽게 하였다. XML의 문법이 다소 긴 점은 장단점을 모두 가질 수 있다고 할수 있다. 사람이 쉽게 읽을수 있는 반면, 불필요한 정보때문에, 처리속도가 늦어질 수 있다. 예를 들어, CORBA , GIOP , ICE 그리고 DCOM 같은 경우에 바이너리 메시지 포맷을 사용하므로 상대적으로 훨씬 전송량이 적습니다. 반면에, 하드웨어적인 장치로, XML 메시지 처리를 빠르게 할 수 있습니다. 바이너리 XML은 스트리밍 전송에 대한 전송속도에 대한 수단으로 검토되고 있는 중입니다.



장점
SOAP를 사용한 HTTP는 기존 원격 기술들에 비해서 프록시와 방화벽에 구애받지 않고 쉽게 통신 가능하다.
SOAP는 융통성있게도 각각 다른 트랜스포트 프로토콜들의 사용을 허용하고 있다. 표준 스택에서는 트랜스 포트 프로토콜로 HTTP를 사용하지만, 다른 프로토콜 역시 사용가능 하다.
SOAP는 플랫폼 독립적이다.
SOAP는 프로그래밍 언어에 독립적이다.
SOAP 간단하고, 확장가능하다.



단점
XML 포맷은 태그 형태로 보내기 때문에 CORBA같은 미들웨어 기술과 비교해서 상대적으로 느리다. 이것은 전송할 메시지가 적을때에는 문제 되지 않을 수 있다. 성능을 향상시키기 위해서 바이너리 객체를 포함시킨 특별한 경우의 XML(바이너리 XML을 말하는듯)로 메시지 전송 최적화 메커니즘(Message Transmission Optimization Mechanism)이 나왔다. 게다가 일반적인 XML의 성능을 향상시키기 위해, VTD-XML과 같은 emerging non-extractiv XML 처리 모델이 있다.



SOAP 샘플

 <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/">
   <SOAP-ENV:Body>
     <getProductDetails xmlns="
http://warehouse.example.com/ws">
       <productId>827635</productId>
     </getProductDetails>
   </SOAP-ENV:Body>
 </SOAP-ENV:Envelope>


+ Recent posts