Webservice 기초

2013. 2. 25. 10:37OpenSource/Apache CXF

반응형




출처 : http://ws6263.blog.me/100156628436

More Detail하게 알아보자^^
출처 : http://ko.wikipedia.org/wiki/SOAP



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)의 개념을 가져왔다.

Acet-T : 웹서비스가 통신(메시지 전달)하기 위한 프로토콜로..HTTP, HTTPS, SMTP 등을 사용하여 메시지를 교환 하며, 내부 메시지는 xml 형태 이다. 구조는 envelope/header/body 로 되어있다.
<<그림>>



밑에 나오는 xml 형태의 soap example


역사

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 Access Protocol)로서 처음으로 디자인되었다. SOAP의 표준화 작업은 현재 W3CXML protocol Working Group 쪽에서 관리를 하고 있다.

전송 방식

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

이는 WS-I방식으로 Basic Profile 1.1에서 서술된 것과 같이 웹 서비스의 보안을 제공하고 있다. 이 점은, GIOP/IIOP 혹은 DCOM 등과 같은 방화벽에서 쉽게 필터링 당하는 여타의 배포 프로토콜등과의 비교 우위를 점하고 있다.

메시지 형식(XML 형식)

XML은 대다수 회사들과 오픈 소스 개발 진영의 노력에 힘입어 광범위하게 사용되는 메시지 형식이므로 표준으로 선택되었다. 게다가 광범위하게 무료로 사용 가능한 툴이 상당수 포진하고 있는 점은 SOAP-기반 구현으로 옮겨가기 쉽게 하였다. XML의 문법은 다소 긴데, 이에는 장단점이 있다. 사람이 쉽게 읽을 수 있는 반면, 불필요한 정보때문에 처리속도가 늦어질 수 있다. CORBA, GIOP, ICE, DCOM은 이진 메시지 포맷을 사용하므로 전송량이 훨씬 적다. 그러나 XML 메시지 처리는 하드웨어로 빠르게 할 수 있다.[1][2] 이진 XML은 스트리밍 전송에 대한 대안으로 (속도를 높이는 수단으로) 검토되고 있다.

장단점 비교

다양한 비평자들과 전문가들이 기술적인 대안과 the context of its intended use에 대하여 SOAP의 기술적인 장단점들에 대한 토의가 있어왔다.

장점

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

단점

  • XML 포맷은 태그 형태로 보내기 때문에 CORBA같은 미들웨어 기술과 비교해서 상대적으로 느리다. 이것은 전송할 메시지가 적을때에는 문제 되지 않을 수 있다. 성능을 향상시키기 위해서 바이너리 객체를 포함시킨 특별한 경우의 XML(바이너리 XML을 말하는듯)로 메시지 전송 최적화 메커니즘(Message Transmission Optimization Mechanism; MTOM)이 나왔다. 게다가 일반적인 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>
 
UDDI
 
UDDI(Universal Description, Discovery and Integration)는 웹 서비스 관련 정보의 
공개와 탐색을 위한 표준이다(???What the..zz)
. 위에서 정의 되어 있는 것을 보면..
웹서비스를 등록, 검색 할 수 있는 등록 저장소 라고 한다.


서비스 제공자는 UDDI라는 서비스 소비자에게
이미 알려진 온라인 저장소에 그들이 제공하는 서비스 목록들을 저장하게 되고,
서비스 소비자들은 그 저장소에 접근함으로써 원하는 서비스들의 목록을 찾을 수 있게 된다.
UDDI 비즈니스 등록은 다음과 같이 세 가지 구성요소를 갖는다.
  • 화이트 페이지(White Pages) — 주소, 연락처 등의 알려져 있는 식별자
  • 옐로 페이지(Yellow Pages) — 표준 분류법을 기반으로 한 산업 분류
  • 그린 페이지(Green Pages) — 비즈니스를 통해 노출된 서비스에 대한 기술 정보
 음...UDDI는 개념으로 봤을 때는 scope가 큰 것 같다.
보통 내부 시스템이라던지 B2B 간의 웹서비스를 통한 통신을 하게 되는데 있어서..
UDDI가 쓰이는지는 현재 구축되어진 것을 봐야 할 것으로 생각 된다.
WSDL
WSDL(Web Services Description Language의 약자)은 웹 서비스 기술언어 또는 기술된 정의 파일의
총칭으로 XML로 기술
된다. 웹 서비스의 구체적 내용이 기술
1) 서비스 제공 장소
2) 서비스 메시지 포맷
3) 프로토콜 등이 기술
WSDL 2.0 문서의 구조:
출처 : http://ko.wikipedia.org/wiki/WSDL
 
반응형