대량 메타데이터 패키지 제출
대량 메타데이터 패키지를 제출하려면 다음을 수행합니다.
SignTool 도구를 사용하여 대량 메타데이터 패키지에 서명합니다.
Microsoft 계정을 사용하여 하드웨어 개발자 센터 또는 Windows 개발자 센터에서 대시보드 에 로그인합니다.
디바이스 메타데이터에서 대량 제출 만들기를 클릭합니다.
새 대량 메타데이터 패키지를 찾아 선택한 다음 제출을 클릭합니다.
대량 제출 패키지 만들기
대량 메타데이터 제출 패키지는 여러 디바이스 메타데이터 패키지를 대시보드에 제출할 수 있는 패키지 형식입니다.
대량 제출 기능을 사용하여 대량 메타데이터 제출 패키지를 대시보드에 업로드해야 합니다. 이 기능은 여러 메타데이터 패키지를 동시에 업로드할 수 있도록 환경을 만들기 위한 사용자 인터페이스를 제거합니다. 환경을 만들고 패키지 특성을 수정하는 정보는 BulkMetadataSubmission XML 문서에 포함되어 있습니다.
최대 50개 devicemetadata-ms 또는 devicemanifest-ms 파일을 대량 패키지에 포함할 수 있습니다.
디바이스 메타데이터 제출 마법사를 사용하여 대량 메타데이터 패키지를 만드는 방법에 대한 자세한 내용은 Visual Studio에서 디바이스 메타데이터 제출 패키지 만들기를 참조하세요.
대량 메타데이터 제출 패키지 콘텐츠
각 대량 메타데이터 제출 패키지는 다음 구성 요소로 구성됩니다.
디바이스 메타데이터 패키지
디바이스 메타데이터 패키지에는 디바이스 아이콘을 표시하고, 작업을 설정하고, 디바이스 환경 기능을 활용하는 정보와 그래픽이 포함되어 있습니다.
디바이스 매니페스트 패키지
디바이스 매니페스트 패키지에는 디바이스 메타데이터 패키지의 유효성을 검사하는 정보가 포함되어 있습니다.
BulkMetadataSubmission XML 문서
이 문서에는 사용자 인터페이스 없이 패키지를 올바르게 제출하는 데 사용되는 데이터가 포함되어 있습니다. 대시보드는 이 문서의 정보를 사용하여 친숙한 이름으로 환경을 만들고, 패키지를 환경으로 구성하고, 환경을 업데이트하고, 개별 패키지를 미리 보기로 표시합니다.
참고
XML 문서는 UTF-8 인코딩을 사용하여 저장해야 합니다.
대량 메타데이터 제출 패키지에 하나 이상의 디바이스 메타데이터 또는 디바이스 매니페스트 패키지를 포함해야 합니다.
대량 메타데이터 제출 패키지의 구조
대량 메타데이터 제출 패키지의 구성 요소는 압축된 캐비닛 파일에 저장됩니다. 파일 이름에 ".bulkmetadata-ms"라는 접미사가 있어야 합니다.
각 대량 메타데이터 제출 패키지에는 다음과 같은 구조가 있어야 합니다.
DDMMYYYY.bulkmetadata-ms
\Filename1.devicemetadata-ms
\Filename2.devicemetadata-ms
\...
\Filename3.devicemanifest-ms
\Filename4.devicemanifest-ms
\...
\BulkMetadataSubmission.xml
Filename1, Filename2, Filename3, Filename4 등은 GUID여야 합니다.
BulkMetadataSubmission.xml 만들려면 아래 BulkMetadataSubmission.xml만들기 를 참조하세요.
디바이스 메타데이터 패키지 *.devicemetadata-ms를 개발하려면 Windows 8 대한 디바이스 메타데이터 패키지 스키마 참조를 참조하세요.
디바이스 매니페스트 패키지 *.devicemanifest-ms를 개발하려면 PC 디바이스 매니페스트 패키지 제출을 참조하세요.
Cabarc 도구를 사용하여 이러한 CAB 패키지를 만들 수 있습니다. 이 도구에 대한 자세한 내용은 Cabarc 개요를 참조하세요.
Cabarc 도구를 사용하여 *.bulkmetadata-ms 파일을 만들 때 디바이스 메타데이터 패키지(*.devicemetadata-ms), 디바이스 매니페스트 패키지(*.devicemanifest-ms) 및 BulkMetadataSubmission XML 문서가 디렉터리의 루트에 있는 로컬 디렉터리를 만들어야 합니다.
설명
.devicemetadata-ms 및 .devicemanifest-ms 파일 이름은 중괄호({}) 구분 기호 없이 GUID를 지정해야 합니다.
각 디바이스 메타데이터 패키지 및 디바이스 매니페스트 패키지에 대한 GUID는 고유해야 합니다. 새 패키지 또는 수정된 패키지를 만들 때 새 GUID를 만들어야 합니다.
캐비닛 파일을 만드는 방법에 대한 자세한 내용은 Microsoft 캐비닛 SDK를 참조하세요.
예제
다음은 Cabarc 도구를 사용하여 .bulkmetadata-ms 파일을 만드는 방법의 예입니다. 이 예제에서 대량 메타데이터 파일의 구성 요소는 BulkPackages라는 로컬 디렉터리에 있습니다.
.\BulkPackages\
.\BulkPackages\BulkMetadataSubmission.xml
.\BulkPackages\GUID1.devicemetadata-ms
.\BulkPackages\GUID2.devicemetadata-ms
.\BulkPackages\GUID3.devicemanifest-ms
.\BulkPackages\GUID4.devicemanifest-ms
GUID.pcmetadata-ms 파일은 PCFiles라는 로컬 디렉터리에 만들어졌습니다.
Cabarc.exe -r -p -P .\BulkPackages\
N .\BulkFiles\ DDMMYYYY.bulkmetadata-ms
.\BulkPackages\BulkMetadataSubmission.xml
.\BulkPackages\GUID1.devicemetadata-ms
.\BulkPackages\GUID2.devicemetadata-ms
.\BulkPackages\GUID3.devicemanifest-ms
.\BulkPackages\GUID4.devicemanifest-ms
참고
이 도구에 대한 자세한 내용은 Cabarc 개요에서 확인할 수 있습니다.
BulkMetadataSubmission.xml 만들기
BulkMetadataSubmission XML 스키마
대량 메타데이터 제출 패키지에는 대시보드에서 친숙한 이름으로 환경을 만들고, 패키지를 환경으로 구성하고, 환경을 업데이트하고, 개별 패키지를 미리 보기로 표시하는 데 사용하는 정보가 포함된 하나의 BulkMetadataSubmission.xml 문서가 포함되어 있습니다.
BulkMetadataSubmission.xml 문서의 데이터는 아래에 설명된 BulkMetadataSubmission XML 스키마에 따라 형식이 지정됩니다.
참고
XML 문서는 UTF-8 인코딩을 사용하여 저장해야 합니다.
BulkMetadataSubmission XML 스키마 네임스페이스
다음은 PcMetadataSubmission XML 스키마의 네임스페이스입니다. http://schemas.microsoft.com/Windows/2010/08/MetadataSubmission/BulkMetadataSubmission
BulkMetadataSubmission XML 요소/특성 개요
다음 표에서는 BulkMetadataSubmission XML 스키마의 메타데이터 요소 및 특성에 대해 설명합니다.
요소/특성 | 요소/특성 유형 | 필수/선택 사항 |
---|---|---|
환경 | ExperienceType | 필수 |
ExperienceName | xs:string | 필수 |
ExperienceId | tns:GUIDType | 선택 사항 |
PackageList | tns:PackageListType | 필수 |
PackageFileName | PackageFileNameType | 필수 |
미리 보기 | xs:Boolean | 필수 |
locale | xs:string | 필수 |
Qualification | tns:QualificationType | 필수 |
LogoSubmissionIDList | tns:LogoSubmissionIDListType | 선택 사항 |
LogoSubmissionID | xs:integer | 필수 |
update | xs:Boolean | 필수 |
BulkMetadataSubmission XML 스키마 메타데이터
다음은 BulkMetadataSubmission XML 스키마 메타데이터입니다.
<?xml version="1.0" encoding="UTF-8"?>
<xs:schema targetNamespace="http://schemas.microsoft.com/Windows/2010/08/MetadataSubmission/BulkMetadataSubmission" xmlns:tns="http://schemas.microsoft.com/Windows/2010/08/MetadataSubmission/BulkMetadataSubmission" xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" blockDefault="#all">
<xs:element name="BulkMetadataSubmission" type="tns:BulkMetadataSubmissionType" />
<xs:complexType name="BulkMetadataSubmissionType">
<xs:sequence>
<xs:element name="Experience" type="tns:ExperienceType" maxOccurs="unbounded" />
<xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
<xs:complexType name="ExperienceType">
<xs:complexContent>
<xs:extension base ="tns:BaseExperienceType">
<xs:attribute name="update" type="xs:boolean" use="required"/>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="BaseExperienceType">
<xs:sequence>
<xs:element name="ExperienceName" type="xs:string" />
<xs:element name="ExperienceId" type="tns:GUIDType" minOccurs="0" />
<xs:element name="PackageList" type="tns:PackageListType" />
<xs:element name="Qualification" type="tns:QualificationType" />
<xs:element name="LogoSubmissionIDList" type="tns:LogoSubmissionIDListType" minOccurs="0" maxOccurs="unbounded" />
<xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
<xs:simpleType name="GUIDType">
<xs:restriction base="xs:string">
<xs:pattern value="[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}" />
</xs:restriction>
</xs:simpleType>
<xs:complexType name="PackageListType">
<xs:sequence>
<xs:element name="PackageFileName" type="tns:PackageFileNameType" maxOccurs="unbounded" />
<xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
<xs:complexType name="PackageFileNameType">
<xs:simpleContent>
<xs:extension base="xs:string">
<xs:attribute name="preview" type="xs:boolean" use="required" />
<xs:attribute name="locale" type="xs:string" use="required" />
</xs:extension>
</xs:simpleContent>
</xs:complexType>
<xs:simpleType name="QualificationType">
<xs:union memberTypes="tns:QualificationTypeEnumeration xs:string" />
</xs:simpleType>
<xs:simpleType name="QualificationTypeEnumeration">
<xs:restriction base="xs:string">
<xs:enumeration value="Logo/IDDA" />
<xs:enumeration value="MicrosoftInboxDriver" />
</xs:restriction>
</xs:simpleType>
<xs:complexType name="LogoSubmissionIDListType">
<xs:sequence>
<xs:element name="LogoSubmissionID" type="xs:integer" maxOccurs="unbounded" />
<xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
</xs:schema>
BulkMetadataSubmission XML 스키마 참조
BulkMetadataSubmission XML 스키마는 다음 요소와 특성을 정의합니다.
BulkMetadataSubmission
환경
ExperienceName
ExperienceID
PackageList
PackageFileName
미리 보기
locale
Qualification
LogoSubmissionIDList
- LogoSubmissionID
update
Experience 요소
Experience 요소는 단일 환경에 대한 정보를 지정합니다. 환경에 대한 자세한 내용은 Windows 8 대한 디바이스 메타데이터 패키지 스키마 참조를 참조하세요.
이 정보에 따라 대시보드는 올바른 정보를 사용하여 환경을 만들고 이 환경에 패키지를 제출하거나 새 패키지로 기존 환경을 업데이트합니다.
<xs:element name="Experience" type="tns:ExperienceType" maxOccurs="unbounded" />
<xs:complexType name="ExperienceType">
<xs:complexContent>
<xs:extension base ="tns:BaseExperienceType">
<xs:attribute name="update" type="xs:boolean" use="required"/>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="BaseExperienceType">
<xs:sequence>
<xs:element name="ExperienceName" type="xs:string" />
<xs:element name="ExperienceId" type="tns:GUIDType" minOccurs="0" />
<xs:element name="PackageList" type="tns:PackageListType" />
<xs:element name="Qualification" type="tns:QualificationType" />
<xs:element name="LogoSubmissionIDList" type="tns:LogoSubmissionIDListType" minOccurs="0" maxOccurs="unbounded" />
<xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
여러 환경을 지정하는 데 둘 이상의 Experience 요소를 사용할 수 있습니다. 이렇게 하면 여러 디바이스에 대한 여러 패키지를 단일으로 제출할 수 있습니다.
예를 들어 다음을 참조하세요.
<Experience update="false">
<ExperienceName>Test1</ExperienceName>
<PackageList>
<PackageFileName locale="en-us" preview ="false">
XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX.devicemanifest-ms
</PackageFileName>
</PackageList>
<Qualification>Logo/IDDA</Qualification>
<LogoSubmissionIDList>
<LogoSubmissionID>XXXXXXX</LogoSubmissionID>
</LogoSubmissionIDList>
</Experience>
<Experience update="false">
<ExperienceName>Test2</ExperienceName>
<PackageList>
<PackageFileName locale="en-us" preview ="false">
XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX.devicemetadata-ms
</PackageFileName>
</PackageList>
<Qualification>Logo/IDDA</Qualification>
<LogoSubmissionIDList>
<LogoSubmissionID>XXXXXXX</LogoSubmissionID>
</LogoSubmissionIDList>
</Experience>
ExperienceName 요소
ExperienceName 요소는 환경의 이름을 지정합니다. 대시보드는 새 환경인 경우 이 이름으로 환경을 만듭니다. 또는 기존 환경에 대한 업데이트인 경우 이 값을 무시합니다.
<xs:element name="ExperienceName" type="xs:string" />
ExperienceId 요소
ExperienceId 요소는 Experience ID인 GUID를 지정합니다. 이 값은 기존 환경을 업데이트할 때 필요합니다. 대시보드는 이 값을 사용하여 업데이트할 환경을 식별합니다.
<xs:element name="ExperienceId" type="tns:GUIDType" minOccurs="0" />
<xs:simpleType name="GUIDType">
<xs:restriction base="xs:string">
<xs:pattern value="[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}" />
</xs:restriction>
</xs:simpleType>
PackageList 요소
PackageList 요소는 환경에 포함할 디바이스 메타데이터 또는 디바이스 매니페스트 패키지 목록을 지정합니다. 대시보드는 이 정보를 사용하여 새 환경이나 기존 환경에 패키지를 추가합니다.
<xs:element name="PackageList" type="tns:PackageListType" />
<xs:complexType name="PackageListType">
<xs:sequence>
<xs:element name="PackageFileName" type="tns:PackageFileNameType" maxOccurs="unbounded" />
<xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
PackageFileName 요소
PackageFileName 요소는 단일 디바이스 메타데이터 또는 디바이스 매니페스트 패키지의 파일 이름과 정보를 지정합니다. 대시보드는 이 정보를 사용하여 새 환경이나 기존 환경에 패키지를 추가하고 표시된 경우 패키지를 미리 보기로 올바르게 표시합니다. 미리 보기 및 로캘 값에 따라 대시보드는 필요한 경우 기존 패키지도 삭제합니다.
<xs:element name="PackageFileName" type="tns:PackageFileNameType" maxOccurs="unbounded" />
<xs:complexType name="PackageFileNameType">
<xs:simpleContent>
<xs:extension base="xs:string">
<xs:attribute name="preview" type="xs:boolean" use="required" />
<xs:attribute name="locale" type="xs:string" use="required" />
</xs:extension>
</xs:simpleContent>
</xs:complexType>
PackageFileName 요소의 미리 보기 및 로캘 특성을 사용하면 대시보드에서 기존 라이브 패키지를 새로 제출된 패키지로 업데이트할 수 있습니다.
예를 들어 환경에 en-US 미리 보기 패키지가 이미 있고 동일한 환경을 위해 대량 메타데이터 제출 패키지에 en-US 미리 보기 패키지가 제출된 경우 기존 패키지가 자동으로 삭제되고 새 패키지가 제출됩니다.
이러한 이유로 패키지를 업데이트할 때 실수로 삭제되지 않도록 주의해야 합니다.
preview 특성
미리 보기 특성은 디바이스 메타데이터 또는 디바이스 매니페스트 패키지를 미리 보기로 표시할지 여부를 지정합니다. 대시보드에서 이 값을 사용하는 방법에 대한 자세한 내용은 PackageFileName 요소를 참조하세요.
<xs:attribute name="preview" type="xs:boolean" use="required" />
로캘 특성
로캘 특성은 디바이스 메타데이터 또는 디바이스 매니페스트 패키지의 선언된 로캘(PackageInfo.xml)을 미리 보기로 표시해야 한다고 지정합니다. 대시보드에서 이 값을 사용하는 방법에 대한 자세한 내용은 PackageFileName 요소를 참조하세요.
<xs:attribute name="locale" type="xs:string" use="required" />
Qualification 요소
Qualification 요소는 디바이스에 로고 인증이 있는지, IDDA(받은 편지함 드라이버 배포 계약) 목록에 포함되는지 또는 Microsoft 받은 편지함 드라이버를 사용하는지 여부를 지정합니다. 대시보드는 이 정보를 사용하여 제출하는 디바이스 메타데이터 유형에 대한 올바른 디바이스 인증을 보장합니다.
<xs:element name="Qualification" type="tns:QualificationType" />
<xs:simpleType name="QualificationType">
<xs:union memberTypes="tns:QualificationTypeEnumeration xs:string" />
</xs:simpleType>
<xs:simpleType name="QualificationTypeEnumeration">
<xs:restriction base="xs:string">
<xs:enumeration value="Logo/IDDA" />
<xs:enumeration value="MicrosoftInboxDriver" />
</xs:restriction>
</xs:simpleType>
로고 인증을 통과하지 않았고 IDDA 목록에 없는 디바이스에는 디바이스 스테이지와 같은 기능을 사용할 수 없습니다.
각 환경에 대해 두 가지 옵션 중 하나를 선택할 수 있습니다. 아래 표에는 이러한 옵션과 각 정의가 나와 있습니다.
열거형 값 | Description |
---|---|
로고/IDDA | 디바이스에 로고 인증이 있거나 IDDA 목록에 있습니다. 로고 인증이 있는 경우 LogoSubmissionIDList 요소에 특정 로고 제출 ID를 지정해야 합니다. |
MicrosoftInboxDrive | 디바이스에서 Microsoft 받은 편지함 드라이버를 사용합니다. 이 자격 수준(예: 디바이스 단계)을 사용할 때 디바이스 메타데이터의 일부 기능을 사용하지 못할 수 있습니다. |
LogoSubmissionIDList 요소
LogoSubmissionIDList 요소는 디바이스의 로고 인증 목록을 지정합니다. 대시보드에서 이 값을 사용하는 방법에 대한 자세한 내용은 Qualification 요소를 참조하세요.
<xs:element name="LogoSubmissionIDList" type="tns:LogoSubmissionIDListType" minOccurs="0" maxOccurs="unbounded" />
<xs:complexType name="LogoSubmissionIDListType">
<xs:sequence>
<xs:element name="LogoSubmissionID" type="xs:integer" maxOccurs="unbounded" />
<xs:any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
LogoSubmissionID 요소
LogoSubmissionID 요소는 디바이스에 대한 개별 로고 인증을 지정합니다. 대시보드에서 이 값을 사용하는 방법에 대한 자세한 내용은 Qualification 요소를 참조하세요.
<xs:element name="LogoSubmissionID" type="xs:integer" maxOccurs="unbounded" />
여러 LogoSubmissionID 요소를 사용하여 단일 디바이스에 대한 여러 로고 인증을 나타낼 수 있습니다. 사용자는 목록에 디바이스에 대한 모든 로고 인증을 나열해야 합니다. 다음은 여러 로고 인증이 나열되는 예제입니다.
<LogoSubmissionIDList>
<LogoSubmissionID>0000001</LogoSubmissionID>
<LogoSubmissionID>0000002</LogoSubmissionID>
<LogoSubmissionID>0000003</LogoSubmissionID>
</LogoSubmissionIDList>
update 특성
업데이트 특성은 환경을 업데이트할지 여부를 지정합니다. 대시보드는 이 값을 사용하여 업데이트 특성이 true로 설정된 경우 충돌하는 패키지를 삭제하고 새 패키지를 업로드하여 환경을 업데이트합니다. 업데이트 특성이 false로 설정되면 대시보드는 새 환경을 만들고 새 패키지를 업로드합니다.
<xs:attribute name="update" type="xs:boolean" use="required"/>
BulkMetadataSubmission XML 예제
다음 XML 문서에서는 BulkMetadataSubmission XML 스키마를 사용하여 BulkMetadataSubmission XML 문서의 구성 요소를 지정합니다.
<BulkMetadataSubmission xmlns="http://schemas.microsoft.com/Windows/2010/08/MetadataSubmission/BulkMetadataSubmission">
<Experience update="false">
<ExperienceName>Test1</ExperienceName>
<PackageList>
<PackageFileName locale="en-us" preview ="false">
XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX.devicemanifest-ms
</PackageFileName>
</PackageList>
<Qualification>Logo/IDDA</Qualification>
<LogoSubmissionIDList>
<LogoSubmissionID>XXXXXXX</LogoSubmissionID>
</LogoSubmissionIDList>
</Experience>
<Experience update="false">
<ExperienceName>Test2</ExperienceName>
<PackageList>
<PackageFileName locale="en-us" preview ="false">
XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX.devicemetadata-ms
</PackageFileName>
</PackageList>
<Qualification>Logo/IDDA</Qualification>
<LogoSubmissionIDList>
<LogoSubmissionID>XXXXXXX</LogoSubmissionID>
</LogoSubmissionIDList>
</Experience>
<Experience update="false">
<ExperienceName>Test3</ExperienceName>
<PackageList>
<PackageFileName locale="en-us" preview="false">
XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX.devicemanifest-ms
</PackageFileName>
</PackageList>
<Qualification>Logo/IDDA</Qualification>
<LogoSubmissionIDList>
<LogoSubmissionID>XXXXXXX</LogoSubmissionID>
</LogoSubmissionIDList>
</Experience>
<Experience update="false">
<ExperienceName>Test4</ExperienceName>
<PackageList>
<PackageFileName locale="en-us" preview="false">
XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX.devicemetadata-ms
</PackageFileName>
</PackageList>
<Qualification>Logo/IDDA</Qualification>
<LogoSubmissionIDList>
<LogoSubmissionID>XXXXXXX</LogoSubmissionID>
</LogoSubmissionIDList>
</Experience>
<Experience update="false">
<ExperienceName>Test5</ExperienceName>
<PackageList>
<PackageFileName locale="en-us" preview="false">
XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX.devicemetadata-ms
</PackageFileName>
</PackageList>
<Qualification>Logo/IDDA</Qualification>
<LogoSubmissionIDList>
<LogoSubmissionID>XXXXXXX</LogoSubmissionID>
</LogoSubmissionIDList>
</Experience>
</BulkMetadataSubmission>