UDDI-퀵 가이드
UDDI는 웹 서비스를 설명, 게시 및 찾기위한 XML 기반 표준입니다.
UDDI는 Universal Description, Discovery, and Integration.
UDDI는 웹 서비스의 분산 레지스트리에 대한 사양입니다.
UDDI는 플랫폼에 독립적 인 개방형 프레임 워크입니다.
UDDI는 SOAP, CORBA, Java RMI 프로토콜을 통해 통신 할 수 있습니다.
UDDI는 WSDL (Web Service Definition Language)을 사용하여 웹 서비스에 대한 인터페이스를 설명합니다.
UDDI는 SOAP 및 WSDL에서 웹 서비스의 세 가지 기본 표준 중 하나로 간주됩니다.
UDDI는 개방형 산업 이니셔티브로, 기업이 서로를 발견하고 인터넷을 통해 상호 작용하는 방식을 정의 할 수 있습니다.
UDDI에는 두 개의 섹션이 있습니다.
서비스의 WSDL 설명에 대한 포인터를 포함한 모든 웹 서비스 메타 데이터의 레지스트리입니다.
해당 레지스트리를 조작하고 검색하기위한 WSDL 포트 유형 정의 세트입니다.
UDDI의 역사
UDDI 1.0은 원래 2000 년 9 월 Microsoft, IBM 및 Ariba에서 발표했습니다.
초기 발표 이후 UDDI 이니셔티브는 Dell, Fujitsu, HP, Hitachi, IBM, Intel, Microsoft, Oracle, SAP 및 Sun을 포함한 300 개 이상의 회사를 포함하도록 성장했습니다.
2001 년 5 월 Microsoft와 IBM은 최초의 UDDI 운영자 사이트를 시작하고 UDDI 레지스트리를 활성화했습니다.
2001 년 6 월 UDDI는 버전 2.0을 발표했습니다.
이 자습서를 작성할 당시 Microsoft와 IBM 사이트는 1.0 사양을 구현했으며 가까운 장래에 2.0 지원을 계획하고있었습니다.
현재 UDDI는 OASIS가 후원합니다.
파트너 인터페이스 프로세스
PIP (파트너 인터페이스 프로세스)는 두 거래 파트너가 데이터를 교환 할 수있는 XML 기반 인터페이스입니다. 수십 개의 PIP가 이미 존재합니다. 그들 중 일부는 여기에 나열되어 있습니다-
PIP2A2 − 파트너가 다른 파트너에게 제품 정보를 문의 할 수 있습니다.
PIP3A2 − 파트너가 특정 제품의 가격 및 가용성을 쿼리 할 수 있습니다.
PIP3A4 − 파트너가 전자 구매 주문을 제출하고 주문 승인을받을 수 있습니다.
PIP3A3 − 파트너가 전자 장바구니의 콘텐츠를 전송할 수 있습니다.
PIP3B4 − 파트너가 특정 발송물의 상태를 조회 할 수 있습니다.
개인 UDDI 레지스트리
인터넷에서 사용 가능한 UDDI 레지스트리의 공용 연합 네트워크를 사용하는 대신 회사 또는 산업 그룹은 자체 개인 UDDI 레지스트리를 구현하도록 선택할 수 있습니다.
이러한 독점 서비스는 회사 또는 업계 그룹의 구성원이 서로 서비스를 공유하고 광고 할 수 있도록하는 유일한 목적으로 설계되었습니다.
UDDI 레지스트리가 글로벌 페더레이션 네트워크의 일부인지 또는 개인 소유 및 운영 레지스트리인지에 관계없이 이들을 모두 하나로 묶는 것은 UDDI 레지스트리 내에서 광고되는 비즈니스와 서비스를 게시하고 찾기위한 공통 웹 서비스 API입니다.
기업이나 회사는 세 가지 유형의 정보를 UDDI 레지스트리에 등록 할 수 있습니다. 이 정보는 UDDI의 세 가지 요소에 포함되어 있습니다.
이 세 가지 요소는-
- 화이트 페이지,
- 옐로우 페이지 및
- 그린 페이지.
화이트 페이지
화이트 페이지에는-
회사 및 비즈니스에 대한 기본 정보입니다.
업체명, 주소, 연락처 전화 번호 등 기본 연락처 정보
회사 세금 ID의 고유 식별자입니다. 이 정보를 통해 다른 사람들이 귀하의 비즈니스 식별 정보를 기반으로 귀하의 웹 서비스를 검색 할 수 있습니다.
전화 번호부
옐로우 페이지에는 회사에 대한 자세한 정보가 포함되어 있습니다. 여기에는 회사가 비즈니스를 수행하려는 모든 사람에게 제공 할 수있는 전자 기능의 종류에 대한 설명이 포함됩니다.
옐로우 페이지는 일반적으로 허용되는 산업 분류 체계, 산업 코드, 제품 코드, 비즈니스 식별 코드 등을 사용하여 회사가 목록을 쉽게 검색하고 원하는 것을 정확하게 찾을 수 있도록합니다.
그린 페이지
그린 페이지에는 웹 서비스에 대한 기술 정보가 포함되어 있습니다. 녹색 페이지를 사용하면 웹 서비스가 발견 된 후 누군가가 웹 서비스에 바인딩 할 수 있습니다. 그것은 포함합니다-
- 다양한 인터페이스
- URL 위치
- 웹 서비스를 찾고 실행하는 데 필요한 검색 정보 및 유사한 데이터.
NOTE− UDDI는 SOAP 기반 웹 서비스를 설명하는 데 제한되지 않습니다. 오히려 UDDI를 사용하여 단일 웹 페이지 또는 이메일 주소에서 SOAP, CORBA 및 Java RMI 서비스에 이르는 모든 서비스를 설명 할 수 있습니다.
UDDI 기술 아키텍처는 세 부분으로 구성됩니다.
UDDI 데이터 모델
UDDI 데이터 모델은 비즈니스 및 웹 서비스를 설명하기위한 XML 스키마입니다. 데이터 모델은 "UDDI 데이터 모델"장에 자세히 설명되어 있습니다.
UDDI API 사양
UDDI 데이터 검색 및 공개를위한 API 사양입니다.
UDDI 클라우드 서비스
이들은 UDDI 사양의 구현을 제공하고 일정에 따라 모든 데이터를 동기화하는 운영자 사이트입니다.
퍼블릭 클라우드라고도하는 UDDI 비즈니스 레지스트리 (UBR)는 복제를 통해 데이터가 동기화 된 여러 노드에서 구축 된 개념적으로 단일 시스템입니다.
현재 클라우드 서비스는 논리적으로 중앙 집중식이지만 물리적으로 분산 된 디렉터리를 제공합니다. 이는 한 루트 노드에 제출 된 데이터가 다른 모든 루트 노드에 자동으로 복제됨을 의미합니다. 현재 데이터 복제는 24 시간마다 발생합니다.
UDDI 클라우드 서비스는 현재 Microsoft와 IBM에서 제공합니다. Ariba는 원래 운영자도 제공 할 계획 이었지만 이후 약속에서 물러났습니다. Hewlett-Packard를 포함한 다른 회사의 추가 운영자는 가까운 장래에 계획되어 있습니다.
개인 UDDI 레지스트리를 설정할 수도 있습니다. 예를 들어 대기업은 모든 내부 웹 서비스를 등록하기 위해 자체 개인 UDDI 레지스트리를 설정할 수 있습니다. 이러한 레지스트리는 루트 UDDI 노드와 자동으로 동기화되지 않으므로 UDDI 클라우드의 일부로 간주되지 않습니다.
UDDI에는 다음 데이터 구조를 설명하는 XML 스키마가 포함되어 있습니다.
- businessEntity
- businessService
- bindingTemplate
- tModel
- publisherAssertion
businessEntity 데이터 구조
비즈니스 항목 구조는 웹 서비스 공급자를 나타냅니다. UDDI 레지스트리 내에서이 구조는 연락처 정보, 산업 범주, 비즈니스 식별자 및 제공된 서비스 목록을 포함하여 회사 자체에 대한 정보를 포함합니다.
다음은 가상 비즈니스의 UDDI 레지스트리 항목의 예입니다.
<businessEntity businessKey = "uuid:C0E6D5A8-C446-4f01-99DA-70E212685A40"
operator = "http://www.ibm.com" authorizedName = "John Doe">
<name>Acme Company</name>
<description>
We create cool Web services
</description>
<contacts>
<contact useType = "general info">
<description>General Information</description>
<personName>John Doe</personName>
<phone>(123) 123-1234</phone>
<email>[email protected]</email>
</contact>
</contacts>
<businessServices>
...
</businessServices>
<identifierBag>
<keyedReference tModelKey = "UUID:8609C81E-EE1F-4D5A-B202-3EB13AD01823"
name = "D-U-N-S" value = "123456789" />
</identifierBag>
<categoryBag>
<keyedReference tModelKey = "UUID:C0B9FE13-179F-413D-8A5B-5004DB8E5BB2"
name = "NAICS" value = "111336" />
</categoryBag>
</businessEntity>
businessService 데이터 구조
비즈니스 서비스 구조는 비즈니스 엔티티가 제공하는 개별 웹 서비스를 나타냅니다. 설명에는 웹 서비스에 바인드하는 방법, 웹 서비스 유형 및 속하는 분류 범주에 대한 정보가 포함됩니다.
다음은 Hello World 웹 서비스에 대한 비즈니스 서비스 구조의 예입니다.
<businessService serviceKey = "uuid:D6F1B765-BDB3-4837-828D-8284301E5A2A"
businessKey = "uuid:C0E6D5A8-C446-4f01-99DA-70E212685A40">
<name>Hello World Web Service</name>
<description>A friendly Web service</description>
<bindingTemplates>
...
</bindingTemplates>
<categoryBag />
</businessService>
businessKey 및 serviceKey 속성 에서 UUID (Universally Unique Identifier) 사용에 유의하십시오 . 모든 비즈니스 항목 및 비즈니스 서비스는 정보를 처음 입력 할 때 레지스트리에서 할당 한 UUID를 통해 모든 UDDI 레지스트리에서 고유하게 식별됩니다.
bindingTemplate 데이터 구조
바인딩 템플릿은 비즈니스 서비스 구조로 표현되는 웹 서비스에 대한 기술적 설명입니다. 단일 비즈니스 서비스에 여러 바인딩 템플릿이있을 수 있습니다. 바인딩 템플릿은 웹 서비스의 실제 구현을 나타냅니다.
다음은 Hello World에 대한 바인딩 템플릿의 예입니다.
<bindingTemplate serviceKey = "uuid:D6F1B765-BDB3-4837-828D-8284301E5A2A"
bindingKey = "uuid:C0E6D5A8-C446-4f01-99DA-70E212685A40">
<description>Hello World SOAP Binding</description>
<accessPoint URLType = "http">http://localhost:8080</accessPoint>
<tModelInstanceDetails>
<tModelInstanceInfo tModelKey = "uuid:EB1B645F-CF2F-491f-811A-4868705F5904">
<instanceDetails>
<overviewDoc>
<description>
references the description of the WSDL service definition
</description>
<overviewURL>
http://localhost/helloworld.wsdl
</overviewURL>
</overviewDoc>
</instanceDetails>
</tModelInstanceInfo>
</tModelInstanceDetails>
</bindingTemplate>
비즈니스 서비스에 여러 바인딩 템플릿이있을 수 있으므로 서비스는 각각 다른 프로토콜 집합이나 다른 네트워크 주소에 바인딩 된 동일한 서비스의 다른 구현을 지정할 수 있습니다.
tModel 데이터 구조
tModel은 마지막 핵심 데이터 유형이지만 잠재적으로 파악하기 가장 어렵습니다. tModel은 기술 모델을 나타냅니다.
tModel은 UDDI 레지스트리에 저장된 다양한 비즈니스, 서비스 및 템플릿 구조를 설명하는 방법입니다. 모든 추상 개념은 UDDI 내에 tModel로 등록 할 수 있습니다. 예를 들어, 새 WSDL 포트 유형을 정의하는 경우 UDDI 내에서 해당 포트 유형을 나타내는 tModel을 정의 할 수 있습니다. 그런 다음 tModel을 해당 비즈니스 서비스의 바인딩 템플릿 중 하나와 연결하여 지정된 비즈니스 서비스가 해당 포트 유형을 구현하도록 지정할 수 있습니다.
다음은 Hello World 인터페이스 포트 유형을 나타내는 tModel의 예입니다.
<tModel tModelKey = "uuid:xyz987..." operator = "http://www.ibm.com"
authorizedName = "John Doe">
<name>HelloWorldInterface Port Type</name>
<description>
An interface for a friendly Web service
</description>
<overviewDoc>
<overviewURL>
http://localhost/helloworld.wsdl
</overviewURL>
</overviewDoc>
</tModel>
publisherAssertion 데이터 구조
이는 자회사 또는 부서와 같은 특정 관계 유형에 따라 둘 이상의 businessEntity 구조를 연결하는 관계 구조입니다.
publisherAssertion 구조는 fromKey (첫 번째 businessKey), toKey (두 번째 businessKey) 및 keyedReference의 세 가지 요소로 구성됩니다.
keyedReference는 tModelKey에 의해 고유하게 참조되는 tModel 내의 keyName keyValue 쌍의 관점에서 주장 된 관계 유형을 지정합니다.
<element name = "publisherAssertion" type = "uddi:publisherAssertion" />
<complexType name = "publisherAssertion">
<sequence>
<element ref = "uddi:fromKey" />
<element ref = "uddi:toKey" />
<element ref = "uddi:keyedReference" />
</sequence>
</complexType>
레지스트리에 액세스 할 수있는 방법 없이는 사용할 수 없습니다. UDDI 표준 버전 2.0은 서비스 소비자 및 서비스 공급자가 레지스트리와 상호 작용할 수 있도록 두 개의 인터페이스를 지정합니다.
소비자가 사용하는 서비스 Inquiry Interface 서비스를 찾고 서비스 공급자는 Publisher Interface 서비스를 나열합니다.
UDDI 인터페이스의 핵심은 UDDI XML 스키마 정의입니다. 이는 모든 정보가 흐르는 기본 UDDI 데이터 유형을 정의합니다.
게시자 인터페이스
게시자 인터페이스는 UDDI 레지스트리에서 항목을 관리하는 서비스 제공 업체를위한 16 가지 작업을 정의합니다.
get_authToken− 인증 토큰을 검색합니다. 모든 게시자 인터페이스 작업에는 요청과 함께 유효한 인증 토큰을 제출해야합니다.
discard_authToken− UDDI 레지스트리에 주어진 인증 토큰을 더 이상 수락하지 않도록 지시합니다. 이 단계는 시스템에서 로그 아웃하는 것과 같습니다.
save_business − UDDI 레지스트리에 포함 된 사업체의 정보를 생성하거나 업데이트합니다.
save_service − 사업체가 제공하는 웹 서비스에 대한 정보를 생성하거나 업데이트합니다.
save_binding − 웹 서비스 구현에 대한 기술 정보를 생성하거나 업데이트합니다.
save_tModel − UDDI 레지스트리에서 관리하는 추상 개념의 등록을 생성하거나 업데이트합니다.
delete_business − UDDI 레지스트리에서 주어진 비즈니스 엔티티를 완전히 제거합니다.
delete_service − UDDI 레지스트리에서 주어진 웹 서비스를 완전히 제거합니다.
delete_binding − UDDI 레지스트리에서 주어진 웹 서비스 기술 세부 사항을 제거합니다.
delete_tModel − UDDI 레지스트리에서 지정된 tModel을 제거합니다.
get_registeredInfo − 모든 비즈니스, 모든 서비스 및 모든 tModel을 포함하여 UDDI 레지스트리가 현재 사용자에 대해 추적하고있는 모든 항목의 요약을 반환합니다.
set_publisherAssertions − 개별 게시자 계정과 관련된 추적 된 모든 관계 주장을 관리합니다.
add_publisherAssertions − 하나 이상의 publisherAssertion이 개별 게시자의 어설 션 컬렉션에 추가되도록합니다.
delete_publisherAssertions − 게시자의 assertion 컬렉션에서 하나 이상의 publisherAssertion 요소를 제거합니다.
get_assertionStatusReport − 개별 게시자 계정에서 관리하는 비즈니스 등록과 관련된 현재 및 미결 게시자 주장의 상태를 결정하기위한 관리 지원을 제공합니다.
get_publisherAssertions − 개별 게시자 계정과 연결된 전체 게시자 어설 션 집합을 가져옵니다.
문의 인터페이스
조회 인터페이스는 UDDI 레지스트리를 검색하고 특정 등록에 대한 세부 정보를 검색하기위한 10 가지 작업을 정의합니다.
find_binding − 기술 바인딩 정보를 기반으로 특정 기준 세트와 일치하는 웹 서비스 목록을 반환합니다.
find_business − 특정 기준 세트와 일치하는 비즈니스 항목 목록을 반환합니다.
find_ltservice − 특정 기준 세트와 일치하는 웹 서비스 목록을 반환합니다.
find_tModel − 특정 기준 세트와 일치하는 tModel 목록을 반환합니다.
get_bindingDetail − 특정 웹 서비스 바인딩 템플릿에 대한 전체 등록 정보를 반환합니다.
get_businessDetail − 기업이 제공하는 모든 서비스를 포함하여 기업의 등록 정보를 반환합니다.
get_businessDetailExt − 사업체에 대한 전체 등록 정보를 반환합니다.
get_serviceDetail − 웹 서비스에 대한 전체 등록 정보를 반환합니다.
get_tModelDetail − tModel에 대한 전체 등록 정보를 반환합니다.
find_relatedBusinesses − uddi-org : relationships 모델을 통해 관련된 비즈니스를 검색합니다.
XYZ가 연락처 정보, 서비스 설명 및 온라인 서비스 액세스 정보를 UDDI에 등록하고자하는 회사를 생각해보십시오. 다음 단계가 필요합니다-
함께 일할 운영자를 선택하십시오. 각 운영자는 레지스트리 복제본에 대한 액세스 권한을 부여하기위한 서로 다른 이용 약관을 가지고 있습니다.
운영자가 제공하는 것과 같은 UDDI 클라이언트를 빌드하거나 획득하십시오.
운영자로부터 인증 토큰을 얻습니다.
업체 정보를 등록합니다. 일치를 검색하는 사람들에게 도움이 될 수있는 정보를 최대한 많이 포함하십시오.
인증 토큰을 해제하십시오.
조회 API를 사용하여 바인딩 템플리트 정보를 포함한 정보 검색을 테스트하여 정보를 얻은 사람이이를 성공적으로 사용하여 서비스와 상호 작용할 수 있는지 확인하십시오.
누군가 주어진 서비스를 검색하고 서비스 제공 업체 중 하나로서 귀하의 비즈니스를 찾고자하는 경우 tModel 정보를 입력하십시오.
변경되는 비즈니스 연락처 정보 및 새로운 서비스 세부 정보를 반영하기 위해 필요에 따라 정보를 업데이트하고 매번 운영자로부터 새 인증 토큰을 획득 및 릴리스합니다. 등록한 데이터를 업데이트하거나 수정해야 할 때마다 데이터를 입력 한 운영자에게 돌아 가야합니다.
다음 예는 XYZ 회사가 정보를 등록하는 방법과 XYZ의 제품 라인을 운반하는 데 관심이있는 유통 업체가 XYZ.com 웹 서비스를 사용하여 회사에 연락하고 주문하는 방법에 대한 정보를 찾는 방법을 보여줍니다.
레지스트리 생성
예를 들어 XYZ.com 개발자는 Microsoft 운영자 중 하나로부터 인증 토큰을받은 후 레지스트리에 게시 할 정보를 결정하고 Microsoft에서 제공하는 UDDI 도구 중 하나를 사용합니다. 필요한 경우 개발자는 Java, C # 또는 VB.NET 프로그램을 작성하여 적절한 SOAP 메시지를 생성 할 수도 있습니다. 여기에 예가 있습니다.
POST /save_business HTTP/1.1
Host: www.XYZ.com
Content-Type: text/xml; charset = "utf-8"
Content-Length: nnnn
SOAPAction: "save_business"
<?xml version = "1.0" encoding = "UTF-8" ?>
<Envelope xmlns = "http://schemas/xmlsoap.org/soap/envelope/">
<Body>
<save_business generic = "2.0" xmlns = "urn:uddi-org:api_v2">
<businessKey = "">
</businessKey>
<name>
XYZ, Pvt Ltd.
</name>
<description>
Company is involved in giving Stat-of-the-art....
</description>
<identifierBag> ... </identifierBag>
...
</save_business>
</Body>
</Envelope>
이 예제는 XYZ Company에 대한 UDDI 비즈니스 엔티티 등록을 요청하는 SOAP 메시지를 보여줍니다. 연산자가 데이터 구조에 대한 UUID 키를 자동으로 생성하기 때문에 키 요소는 비어 있습니다. 간단한 예를 보여주기 위해 대부분의 필드는 생략되었습니다.
회사 XYZ는 항상 다른 save_business 작업을 실행하여 비즈니스 항목을 만드는 데 필요한 기본 정보를 추가 할 수 있습니다.
정보 검색
XYZ Company가 관련 정보로 UDDI 항목을 업데이트 한 후 XYZ 배포자가 되고자하는 회사는 UDDI 레지스트리에서 연락처 정보를 조회하고 XYZ.com이 온라인으로 게시하는 두 웹 서비스에 대한 서비스 설명 및 액세스 포인트를 얻을 수 있습니다. 주문 입력 : 프리 시즌 대량 주문 및 시즌 재입고 주문.
이 예는 XYZ 회사에 대한 비즈니스 세부 정보를 얻기위한 샘플 SOAP 요청을 보여줍니다. 등록 된 특정 비즈니스의 UUID 또는 키를 알고 나면 get_businessDetail API에서이를 사용하여 해당 비즈니스에 대한 특정 정보를 반환 할 수 있습니다.
POST /get_businessDetail HTTP/1.1
Host: www.XYZ.com
Content-Type: text/xml; charset = "utf-8"
Content-Length: nnnn
SOAPAction: "get_businessDetail"
<?xml version = "1.0" encoding = "UTF-8" ?>
<Envelope xmlns = "http://schemas/xmlsoap.org/soap/envelope/">
<Body>
<get_businessDetail generic = "2.0" xmlns = "urn:uddi-org:api_v2">
<businessKey = "C90D731D-772HSH-4130-9DE3-5303371170C2">
</businessKey>
</get_businessDetail>
</Body>
</Envelope>
UDDI 데이터 모델은 비즈니스 및 게시하는 웹 서비스에 대한 정보를 저장하기위한 일반 구조를 정의합니다. UDDI 데이터 모델은 정보의 여러 반복되는 시퀀스 구조를 포함하여 완전히 확장 가능합니다.
그러나 WSDL은 웹 서비스의 인터페이스를 설명하는 데 사용됩니다. WSDL은 UDDI와 함께 사용하기 매우 간단합니다.
WSDL은 businessService, bindingTemplate 및 tModel 정보 의 조합을 사용하여 UDDI로 표시됩니다 .
UDDI에 등록 된 모든 서비스와 마찬가지로 서비스에 대한 일반 정보는 businessService 데이터 구조에 저장되며 서비스에 액세스하는 방법과 위치에 대한 정보는 하나 이상의 연관된 bindingTemplate 구조에 저장됩니다 . 각 bindingTemplate 구조는 서비스의 네트워크 주소를 포함하고 서비스 를 설명하고 고유하게 식별하는 하나 이상의 tModel 구조 와 연관된 요소를 포함합니다 .
UDDI가 WSDL 정보 또는 WSDL 파일에 대한 포인터를 저장하는 데 사용되는 경우 tModel 은 규칙에 따라 wsdlSpec 유형으로 참조되어야합니다 . 이는 overviewDoc 요소가 WSDL 서비스 인터페이스 정의를 가리키는 것으로 명확하게 식별 됨을 의미합니다 .
UDDI의 경우 WSDL 컨텐츠는 인터페이스 파일과 구현 파일의 두 가지 주요 요소로 분할됩니다.
Hertz 예약 시스템 웹 서비스는 UDDI와 WSDL이 함께 작동하는 방법에 대한 구체적인 예를 제공합니다. 다음은이 웹 서비스에 대한 <tModel>입니다.
<tModel authorizedName = "..." operator = "..." tModelKey = "...">
<name>HertzReserveService</name>
<description xml:lang = "en">
WSDL description of the Hertz reservation service interface
</description>
<overviewDoc>
<description xml:lang = "en">
WSDL source document.
</description>
<overviewURL>
http://mach3.ebphost.net/wsdl/hertz_reserve.wsdl
</overviewURL>
</overviewDoc>
<categoryBag>
<keyedReference tModelKey = "uuid:C1ACF26D-9672-4404-9D70-39B756E62AB4"
keyName = "uddi-org:types" keyValue = "wsdlSpec"/>
</categoryBag>
</tModel>
요점은-
overviewURL 요소는 서비스 인터페이스 정의 WSDL 파일을 찾을 수있는 URL을 제공합니다. 이를 통해 사람과 UDDI / WSDL 인식 도구가 서비스 인터페이스 정의를 찾을 수 있습니다.
categoryBag에서 keyedReference 요소의 목적은이 tModel이 WSDL 사양 문서로 분류되도록하는 것입니다.
현재 많은 UDDI 구현을 사용할 수 있습니다. 이러한 구현을 통해 UDDI API의 복잡성에 빠져들지 않고도 UDDI 데이터를보다 쉽게 검색하거나 게시 할 수 있습니다. 다음은 사용 가능한 주요 UDDI 구현에 대한 간략한 개요입니다.
자바 구현
Java 용 UDDI 구현에는 두 가지가 있습니다.
UDDI4J (Java 용 UDDI) -UDDI4J는 원래 IBM에서 만들었습니다. 2001 년 1 월 IBM은 코드를 자체 오픈 소스 사이트로 넘겼습니다. UDDI4J는 UDDI와 상호 작용하는 API를 제공하는 Java 클래스 라이브러리입니다.
jUDDI -jUDDI는 UDDI 레지스트리의 오픈 소스 Java 구현이며 UDDI 서비스에 액세스하기위한 툴킷입니다.
Perl 구현
UDDI::Lite − 조회 및 게시를위한 기본 UDDI 클라이언트를 제공합니다.
Ruby 구현
UDDI4r − 조회 및 게시를위한 기본 UDDI 클라이언트를 제공합니다.
Python 구현
UDDI4Py − UDDI4Py는 UDDI 버전 2 API로 요청을 보내고 응답을 처리 할 수있는 Python 패키지입니다.
UDDI 프로젝트는 다양한 사양 API에서 사용하는 데이터 형식을 설명하는 XML 스키마 정의 집합도 정의합니다. 이러한 문서는 모두 www.uddi.org 에서 다운로드 할 수 있습니다 . 모든 사양 그룹의 현재 버전은 버전 2.0입니다.
사양은 다음과 같습니다-
- UDDI 복제,
- UDDI 연산자,
- UDDI 프로그래머의 API 및
- UDDI 데이터 구조
UDDI 복제
이 문서는 레지스트리 운영자가 사이트 간 데이터 복제를 달성하기 위해 준수해야하는 데이터 복제 프로세스 및 인터페이스를 설명합니다. 이 사양은 프로그래머의 API가 아닙니다. UBR 노드간에 사용되는 복제 메커니즘을 정의합니다.
UDDI 연산자
이 문서는 UDDI 노드 운영자가 요구하는 동작 및 운영 매개 변수를 설명합니다. 이 사양은 운영자가 준수해야하는 데이터 관리 요구 사항을 정의합니다.
UDDI 프로그래머의 API
이 사양은 모든 UDDI 레지스트리가 레지스트리에서 호스팅되는 서비스에 대한 조회 및 비즈니스 또는 서비스에 대한 정보를 레지스트리에 게시하기 위해 지원하는 기능 세트를 정의합니다. 이 사양은 UDDI 레지스트리가 수락, 구문 분석 및 응답하는 XML 문서를 포함하는 일련의 SOAP 메시지를 정의합니다. 이 사양은 UDDI XML API 스키마 및 UDDI 데이터 구조 사양과 함께 UDDI 레지스트리에 대한 완전한 프로그래밍 인터페이스를 구성합니다.
UDDI 데이터 구조
이 사양은 UDDI 프로그래머의 API에 의해 정의 된 SOAP 메시지 내에 포함 된 XML 구조의 세부 사항을 다룹니다. 이 사양은 5 가지 핵심 데이터 구조와 서로 간의 관계를 정의합니다.
UDDI XML API 스키마는 사양에 포함되어 있지 않습니다. 오히려 UDDI 데이터 구조의 구조와 데이터 유형을 정의하는 XML 스키마 문서로 저장됩니다.
이 튜토리얼의 UDDI와 그 요소는 UDDI의 완전한 아키텍처와 데이터 모델을 보았습니다.
두 가지 UDDI 인터페이스 인 Publisher 's Interface와 Inquiry Interface에 대해 배웠습니다. 또한 UDDI로 웹 서비스를 등록하고 검색하는 방법도 배웠습니다.
무엇 향후 계획?
다음 단계는 SOAP, WSDL 및 웹 서비스에 대해 배우는 것입니다.
비누
SOAP는 응용 프로그램이 HTTP를 통해 정보를 교환 할 수 있도록하는 간단한 XML 기반 프로토콜입니다.
SOAP에 대해 자세히 알아 보려면 SOAP 자습서 를 방문하십시오 .
WSDL
WSDL은 웹 서비스를 XML 형식으로 설명하기위한 표준 형식입니다.
WSDL은 UDDI의 필수 부분입니다.
WSDL에 대해 자세히 알아 보려면 WSDL 자습서 를 방문하십시오 .
웹 서비스
웹 서비스는 애플리케이션을 웹 애플리케이션으로 변환 할 수 있습니다.
웹 서비스에 대해 자세히 알아 보려면 웹 서비스 튜토리얼을 방문하십시오 .
다음은 UDDI 조회 API 및 UDDI 게시 API의 전체 참조입니다.
UDDI 조회 API
API 이름 | 기술 | V1.0 | V2.0 |
---|---|---|---|
find_binding | 지정된 서비스와 연관된 템플릿 바인딩을 검색합니다. | 와이 | 와이 |
find_business | 지정된 기준과 일치하는 비즈니스를 검색합니다. | 와이 | 와이 |
find_relatedBusinesses | uddi-org : relationships 모델을 통해 관련된 비즈니스를 검색합니다. | 와이 | |
find_service | 지정된 비즈니스와 관련된 서비스를 검색합니다. | 와이 | 와이 |
find_tModel | 지정된 기준과 일치하는 tModel 레코드를 검색합니다. | 와이 | 와이 |
get_bindingDetail | 지정된 각 bindingKey에 대한 전체 bindingTemplate을 검색합니다. | 와이 | 와이 |
get_businessDetail | 지정된 각 businessKey에 대한 전체 businessEntity를 검색합니다. | 와이 | 와이 |
get_businessDetailExt | 지정된 각 businessKey에 대해 확장 된 businessEntity를 검색합니다. | 와이 | 와이 |
get_serviceDetail | 지정된 각 serviceKey에 대한 businessService 레코드를 검색합니다. | 와이 | 와이 |
get_tModelDetail | 지정된 각 tModelKey에 대한 tModel 레코드를 검색합니다. | 와이 | 와이 |
UDDI 게시 API
API 이름 | 기술 | V1.0 | V2.0 |
---|---|---|---|
get_authToken | 인증 토큰을 검색합니다. 모든 게시자 인터페이스 작업에는 요청과 함께 유효한 인증 토큰을 제출해야합니다. | 와이 | 와이 |
폐기 _ 인증 토큰 | UDDI 레지스트리에 주어진 권한 부여 토큰을 더 이상 승인하지 않도록 지시합니다. 이 단계는 시스템에서 로그 아웃하는 것과 같습니다. | 와이 | 와이 |
save_business | UDDI 레지스트리에 포함 된 비즈니스 엔티티의 정보를 작성하거나 업데이트합니다. | 와이 | 와이 |
save_service | 비즈니스 엔티티가 제공하는 웹 서비스에 대한 정보를 작성하거나 업데이트합니다. | 와이 | 와이 |
save_binding | 웹 서비스 구현에 대한 기술 정보를 작성하거나 업데이트합니다. | 와이 | 와이 |
save_tModel | UDDI 레지스트리가 관리하는 추상 개념의 등록을 작성하거나 업데이트합니다. | 와이 | 와이 |
delete_business | UDDI 레지스트리에서 지정된 비즈니스 엔티티를 완전히 제거합니다. | 와이 | 와이 |
delete_service | UDDI 레지스트리에서 제공된 웹 서비스를 완전히 제거합니다. | 와이 | 와이 |
delete_binding | UDDI 레지스트리에서 제공된 웹 서비스 기술 세부 사항을 제거합니다. | 와이 | 와이 |
delete_tModel | UDDI 레지스트리에서 지정된 tModel을 제거합니다. | 와이 | 와이 |
get_registeredInfo | 모든 비즈니스, 모든 서비스 및 모든 tModel을 포함하여 UDDI 레지스트리가 현재 사용자에 대해 추적하고있는 모든 것에 대한 요약을 리턴합니다. | 와이 | 와이 |
set_publisherAssertions | 개별 게시자 계정과 연결된 모든 추적 된 관계 어설 션을 관리합니다. | 와이 | |
add_publisherAssertions | 하나 이상의 publisherAssertion이 개별 게시자의 어설 션 컬렉션에 추가되도록합니다. | 와이 | |
delete_publisherAssertions | 게시자의 어설 션 컬렉션에서 하나 이상의 publisherAssertion 요소가 제거되도록합니다. | 와이 | |
get_assertionStatusReport | 개별 게시자 계정에서 관리하는 비즈니스 등록과 관련된 현재 및 미해결 게시자 주장의 상태를 결정하기위한 관리 지원을 제공합니다. | 와이 | |
get_publisherAssertions | 개별 게시자 계정과 연결된 전체 게시자 어설 션 집합을 가져옵니다. | 와이 |
오류 코드 참조
UDDI API에 의해 반환 된 오류 코드의 전체 참조는 다음과 같습니다.
오류 코드