한국더블린코어 로고
about Documents
Group Resoursces Tools & software
Projects DCMI News
Dublin Core Metadata Initiative

더블린코어를 HTML/XHTML의 meta와 link 요소로 표현하는 기법

생성자: Andy Powell
UKOLN, University of Bath
발행일자: 2003-11-30
식별자: http://dublincore.org/documents/2003/11/30/dcq-html/
대체함: http://dublincore.org/documents/2003/10/31/dcq-html/
대체됨: 해당사항 없음
최신 버전: http://dublincore.org/documents/dcq-html/
문서의 지위: DCMI 권고사항.
해설: 이 문서는 더블린코어 메타데이터를 HTML/XHTML의 <meta>와 <link> 요소로 부호화하는 방법을 설명하고 있다.

1. 서론

이 문서는 HTML/XHTML의 요소를 사용하여 더블린코어 [DCMI] 메타데이터 레코드를 HTML/XHTML 웹 페이지에 내장할 수 있는 방법을 설명하고 있다.

DC 레코드를 HTML/XHTML [HTML] 자원과(혹은 DC 레코드를 HTML/XHTML자원에 내장하기 위한) 연결하기 위한 여러 가지 대안이 있을 수 있음을 유의할 필요가 있다. 여기에는 다음과 같은 대안들이 포함된다.

  • 별도의 RDF/XML [DCRDF, QDCRDF] 기술을 작성하고 HTML/XHTML의 <link> 요소를 사용하여 이 기술과 연결하는 방법
  • 별도의 XML 기술 [DCXML]을 작성하고 HTML/XHTML의 <link> 요소를 사용하여 이 기술과 연결하는 기법

이상의 대안에 대해서는 이 문서에서 다루지 않고 있다.

1.1 전문용어

이 문서에서는 다음과 같은 전문용어를 사용한다.

자원(Resource)
독자성을 지닌 것이라면 어떤 것이라도 자원이 될 수 있다. 흔히 볼 수 있는 용어로는 전자문서와 이미지, 서비스(예, “로스 엔젤리스의 오늘의 기상보고”), 기타 자원의 집서 등이 포함된다. 모든 자원이 네트워크상에서 ‘검색 가능한’ 것은 아니다. 예를 들어 사람과 단체, 도서관에 소장된 제본된 단행본도 자원으로 취급된다.
속성(Property)
레코드는 자원에 관해 얼 마간 구조화된 메타데이터로서, 하나 이상의 속성과 이와 관련된 값으로 구성된다.
레코드(Record)
레코드는 자원에 관해 얼 마간 구조화된 메타데이터로서, 하나 이상의 속성과 이와 관련된 값으로 구성된다.

더블린코어 메타데이터 요소는 속성이라는 점에 유의해야 한다(위에서 정의한 바와 같이). 아울러 HTML/XHTML에서 사용되는 ‘element’와 ‘attribute’라는 용어의 용법과 혼란이 있을 수 있으며, 또 일반적인 메타데이터라는 의미에서 사용되는 이들 용어의 용법 간에 혼란이 있을 수 있다는 점도 유의할 필요가 있다.

이 문서에서 기술대상인 자원은 HTML/XHTML 웹 페이지이고, 이 자원을 기술한 더블린코어 레코드는 HTML/XHTML <meta> 요소를 사용하여 이 웹 페이지에 내장된다는 점도 유의해야 한다. 이 방법을 통해서는 단 하나의 자원(이 웹 페이지)만을 기술할 수 있다. 복수의 자원(예를 들어 복수의 이미지)을 기술하기 위해서는 복수의 더블린코어 레코드를 수록하고 있는 하나 이상의 별도의 XML이나 RDF/XML 문서와 연결해야 한다.

2. XHTML 부호화

여기서 설명하고 있는 <meta>와 <link> 요소를 사용하여 메타데이터를 XHTML 웹 페이지 [XHTML11]의 < head > 부분에 내장해야 한다.

2.1 요소와 값

DC 요소(열다섯 개의 DCMES 중 하나 혹은 더블린코어에서 정의하고 있는 다른 요소 중의 하나, 예를 들면 audience)와 그 값을 부호화하기 위해서는 XHTML <meta> 요소의 'name'과 'content' 성질을 사용해야 한다. 다음과 같은 형식을 따르게 된다.

<meta name="DC.element" content="Value" />
<meta name="DCTERMS.element" content="Value" />

예를 들면 다음과 같다.

<meta name="DC.date" content="2001-07-18" />
<meta name="DCTERMS.audience" content="software developers" />

일반적으로 요소명은 대소문자를 혼용하여 표현할 수 있지만 첫 번째 문자는 항상 소문자로 시작되어야 한다.

'content' 성질의 값은 CDATA, 즉 문자를 포함한 문서의 문자 집합에 있는 일련의 문자로 정의된다. 값이 긴 경우에는 필요에 따라 여러 행으로 표현될 수 있다.

2.2 요소 세목

요소 세목도 XHTML <meta> 요소의 'name'과 'content' 성질을 사용하여 부호화될 수 있다. 다음과 같은 형식을 따르게 된다.

<meta name="DCTERMS.elementRefinement" content="Value" />

예를 들면 다음과 같다.

<meta name="DCTERMS.modified" content="2001-07-18" />

요소 세목에서는 더블린코어 메타데이터 용어(DCMI Metadata Terms) 권고사항에서 구체적으로 제시하고 있는 이름을 사용해야 한다('Label'로 제시된 것이 아니라 'Name'으로 제시된 것). 일반적으로 요소 세목명에는 대소문자를 함께 사용할 수 있지만 첫 번째 문자는 항상 소문자로 시작되어야 한다.

2.3 부호화 체계

부호화 체계는 XHTML <meta> 요소의 'scheme' 성질을 사용하여 부호화되며, 다음과 같은 형식을 따르게 된다.

<meta name="DC.element" scheme="DCTERMS.Scheme" content="Value" />

예를 들면 다음과 같다.

<meta name="DC.date" scheme="DCTERMS.W3CDTF" content="2001-07-18" />
<meta name="DC.type" scheme="DCTERMS.DCMIType" content="Text" />

부호화 체계에서는 더블린코어 메타데이터 용어(DCMI Metadata Terms) 권고사항에서 구체적으로 제시하고 있는 이름을 사용해야 한다('Label'로 제시된 것이 아니라 'Name'으로 제시된 것). 일반적으로 부호화 체계명에는 대소문자를 함께 사용할 수 있지만 첫 번째 문자는 항상 대문자로 시작해야 한다. 대체적으로 부호화 체계명은 모두 대문자이다.

2.4 다른 자원과의 연결

속성의 값이 다른 자원의 URI인 경우(예를 들어 DC.relation 요소에서 흔히 볼 수 있다), XHTML <link> 요소를 사용하여 또 다른 형식으로 부호화하도록 권장되고 있다. 다음과 같은 형식을 따르게 된다.

<link rel="propertyName" href="resourceURI" />

예를 들면 다음과 같다.

<link rel="DC.relation" href="http://www.example.org/" />
<link rel="DCTERMS.references" href="http://www.example.org/publications/2002/176459.pdf" />

때로는 더블린코어 및 기타 ‘연결유형’('Link types')의 리스트 [XHTMLLINK]를 부호화하는 것이 적절할 수 있다. 예를 들면 다음과 같다.

<link rel="DC.rights copyright" href="http://www.example.org/rights.html" />
<link rel="DCTERMS.tableOfContents contents" href="http://www.example.org/toc.html" />

2.5 값의 언어

값의 언어가 제시된 경우에는 XHTML <meta> 요소의 'xml:lang' 성질 및 XHTML 요소의 'hreflang' 성질을 사용하여 이 값 언어를 부호화해야 한다. 예를 들면 다음과 같다.

<meta name="DC.subject" xml:lang="en-GB" content="seafood" />
<meta name="DC.subject" xml:lang="fr" content="fruits de mer" />
<link rel="DC.relation" hreflang="en" href="http://www.example.org/en/" />
<link rel="DC.relation" hreflang="de" href="http://www.example.org/de/" />

2.6 반복된 요소와 요소 세목

복수의 속성 값은 그 속성에 대한 XHTML <meta> 요소를 반복하여 부호화 되어야 한다. 예를 들면 다음과 같다.

<meta name="DC.title" content="First title" />
<meta name="DC.title" content="Second title" />

반복된 요소와 요소 세목의 순서는 여러 소프트웨어 어플리케이션에서 그대로 유지된다고 보장할 수 없다는 점에 유의할 필요가 있다.

2.7 이름공간과 프로파일 고려사항

위의 속성명에 있는 'DC.'와 'DCTERMS.'과 같은 접두어는 그 속성이 속한 이름공간 [DCNS]을 지시하기 위해 사용된 것이다. 이 이름공간 URI는 XHTML <link> 요소 [RELSCHEMA]에서 부호화되어야 하며, 다음과 같은 형식을 사용한다.

<link rel="schema.prefix" href="namespaceURI" />

예를 들면 다음과 같다.

<link rel="schema.DC" href="http://purl.org/dc/elements/1.1/" />
<link rel="schema.DCTERMS" href="http://purl.org/dc/terms/" />

비록 어떤 문자열이라도 접두어로 사용될 수 있지만 'DC.'와 'DCTERMS.'를 사용하도록 권장되고 있다.

더블린코어 메타데이터를 부호화하기 위해 사용된 XHTML 프로파일을 수신자 소프트웨어 어플리케이션에 알리기 위해서는 다음과 같이 XHTML <head> 요소의 'profile' 성질을 사용해서 이 더블린코어 권고사항의 URI를 제공해야 한다.

<head profile="http://dublincore.org/documents/dcq-html/">

3. 기타 더블린코어 권고사항과의 호환성

이 문서의 기존 버전(그리고 다른 DCMI HTML 부호화 문서)에서는 다음과 같이 이 문서에서 제안한 사항과는 다른 권고사항을 일부 제안한 바 있다.

  1. 기존의 권고사항에서는 DCMES 요소명의 첫 번째 문자를 대문자로 사용하도록 규정하였다. 예를 들면 'title' 대신 'Title'을 사용하도록 규정하였다.
  2. 기존의 권고사항에서는 요소 세목 앞에 해당 요소를 접두어로 사용하도록 규정하였다. 예를 들면 'DCTERMS.modified'가 아니라 'DC.Date.modified'를 사용하도록 규정하였다.
  3. 기존의 권고사항에서는 부호화 체계명에 대한 이름공간 접두어의 사용을 구체적으로 제안한 바가 없다. 예를 들면 'DCTERMS.URI'가 아니라 'URI'로 제안하였다.
  4. 기존의 권고사항에서는 다른 자원의 URI를 값으로 가진 속성을 부호화하기 위해 HTML/XHTML 요소의 사용을 구체적으로 제안한 바가 없다.

이상의 부호화 형식은 수용할 수는 있으나 더 이상 사용이 권장되는 형식이 아니다.

일반적으로 HTML/XHTML 웹 페이지에 내장된 DC 레코드를 사용하는 소프트웨어 어플리케이션에서는 DC 이름공간 접두어와 요소명, 요소 세목명의 대소문자를 무시해야 한다. 즉 다음과 같은 형식 모두는 대등한 것으로 취급되어야 한다.

<meta name="DC.date" content="2001-07-18" />
<meta name="DC.Date" content="2001-07-18" />
<meta name="dc.date" content="2001-07-18" />

따라서 다음과 같은 형식으로 사용되어야 한다.

<meta name="DC.Date.modified" content="2001-07-18" />
<meta name="DCTERMS.modified" content="2001-07-18" />

그리고 다음과 같은 형식도 사용된다.

<meta name="DC.Date" scheme="W3CDTF" content="2001-07-18" />
<meta name="dc.date" scheme="dcterms.W3CDTF" content="2001-07-18" />

모든 어플리케이션에서는 위의 권고사항에 따라 메타데이터를 작성해야 한다.

4. 이전 버전의 HTML과의 호환성

이 문서에 제시된 모든 용어는 XHTML 1.1에 따른 것이다. 이 문서의 권고사항은 XHTML 1.0 (예, HTML 4.01 [HTML401])) 이전의 HTML 버전에도 적용이 가능하지만, HTML의 이전 버전에서는 HTML의 <meta> 와 <link> 요소에서 종료 ‘>’ 앞에 오는 ‘/’을 필요로 하지 않기 때문에 최종적으로 작성된 구문에서는 약간의 차이가 있을 수 있다. 게다가 HTML 4.01과 이보다 더 오래된 HTML 버전에서는 값의 언어를 지시하기 위해 'xml:lang' 대신 'lang'을 사용해야만 하였다. XHTML 1.0 Transitional(즉 HTML과 호환이 가능하도록 설계된 XHTML)에서는 'lang'과 'xml:lang' 두 가지를 사용해야 하고, XHTML의 기타 버전에서는(1.1과 같은) xml:lang 만을 사용해야 한다.

5. DC 메타데이터와 다른 체계와의 혼합

DC 메타데이터는 HTML/XHTML <meta> 요소에서 DC 이외의 메타데이터와 혼용해서 사용이 가능하다. 다음 예는 동일한 HTML/XHTML 웹 페이지에 DC와 AGLS [AGLS] 그리고 명시적으로 제시되지 않은 메타데이터 속성을 내장하고 있다.

<link rel="schema.DC" href="http://purl.org/dc/elements/1.1/" />
<link rel="schema.AGLS" href="http://www.naa.gov.au/recordkeeping/gov_online/agls/1.2" />

<meta name="DC.title" content="Services to Government" />
<meta name="AGLS.Function" scheme="AGIFT" content="recordkeeping standards" />
<meta name="keywords" content="archives, information management,
public administration" />

속성과 부호화 체계에 이름을 부여하기 위한 더블린코어 규정은 DC 이외의 메타데이터 요소에는 적용되지 않는다는 점을 유의할 필요가 있다.

6. 용어

이 문서에 대한 확장 DC 메타데이터 레코드를 다음과 같이 제시하였다. 이 웹 페이지의 HTML 정보원의 <head> 부분에 이 레코드가 내장되어 있다는 것도 알 수 있을 것이다.

...
<head profile="http://dublincore.org/documents/dcq-html/">
<title>Expressing Dublin Core in HTML/XHTML meta and link elements</title>
<link rel="schema.DC" href="http://purl.org/dc/elements/1.1/" />
<link rel="schema.DCTERMS" href="http://purl.org/dc/terms/" />

<meta name="DC.title" lang="en" content="Expressing Dublin Core
in HTML/XHTML meta and link elements" />
<meta name="DC.creator" content="Andy Powell, UKOLN, University of Bath" />
<meta name="DCTERMS.issued" scheme="DCTERMS.W3CDTF" content="2003-11-01" />
<meta name="DC.identifier" scheme="DCTERMS.URI"
content="http://dublincore.org/documents/dcq-html/" />
<link rel="DCTERMS.replaces" hreflang="en"
href="http://dublincore.org/documents/2000/08/15/dcq-html/" />
<meta name="DCTERMS.abstract" content="This document describes how
qualified Dublin Core metadata can be encoded
in HTML/XHTML &lt;meta&gt; elements" />
<meta name="DC.format" scheme="DCTERMS.IMT" content="text/html" />
<meta name="DC.type" scheme="DCTERMS.DCMIType" content="Text" />
</head>
...

7. 감사의 글

이 문서는 더블린코어 메타데이터를 HTML [RFC2731]로 부호화하기 위한 기존의 권고사항과 Simon Cox와 Eric Miller, Andy Powell이 작성한 이 문서의 이전 버전, 웹에서의 현재의 관행 및 HTML/XHTML 규격의 최신 버전에 기초한 것이다.

8. 참고문헌

[DCMI]
Dublin Core Metadata Initiative
http://dublincore.org/

[HTML]
HyperText Markup Language (HTML)
http://www.w3.org/MarkUp/

[DCRDF]
Expressing Simple Dublin Core in RDF/XML
Dave Beckett, Eric Miller, Dan Brickley, 2001
http://dublincore.org/documents/dcmes-xml/

[QDCRDF]
Expressing Qualified Dublin Core in RDF / XML
Stefan Kokkelink, Roland Schwdnzl, 2002
http://dublincore.org/documents/dcq-rdf-xml/

[DCXML]
Guidelines for implementing Dublin Core in XML
Andy Powell, Pete Johnston
http://dublincore.org/documents/dc-xml-guidelines/

[DCMES]
Dublin Core Metadata Element Set, Version 1.1: Reference Description
http://dublincore.org/documents/dces/

[DCTERMS]
DCMI Metadata Terms
http://dublincore.org/documents/dcmi-terms/

[XHTML11]
XHTML 1.1: Module-based XHTML
W3C Recommendation, May 2001
http://www.w3.org/TR/xhtml11

[XHTMLLINK]
The 'link'-Element in (X)HTML
http://www.subotnik.net/html/link

[DCNS]
Namespace Policy for the Dublin Core Metadata Initiative (DCMI)
http://dublincore.org/documents/dcmi-namespace/

[RELSCHEMA]
A Proposed Convention for Embedding Metadata in HTML
http://www.w3.org/Search/9605-Indexing-Workshop/ReportOutcomes/S6Group2.html

[HTML401]
HTML 4.01 Specification
Dave Raggett, Arnaud Le Hors, Ian Jacobs, 1999
http://www.w3.org/TR/html40/

[AGLS]
AGLS Metadata Standard
http://www.naa.gov.au/recordkeeping/gov_online/agls/summary.html

[RFC2731]
Encoding Dublin Core metadata in HTML
John Kunze, 1999
http://www.ietf.org/rfc/rfc2731.txt

 
 

COPYRIGTH (C) 2006 THE NATIONAL LIBRARY OF KOREA, ALL RIGHT RESERVED