Açık Paketleme Kurallarının Dijital İmzalama Çerçevesi

 

David Meltzer ve Andrey Shur
Microsoft Corporation

Eylül 2006

Aşağıdakiler cihazlar için geçerlidir:
   OPC Dijital İmzalama Çerçevesi
   W3C XML Dijital İmza standardı
   Microsoft .NET 3.0 Framework

Özet: Paket bileşenlerine ve destekleyici hizmetlere genel bir bakış sağlayan OPC Dijital İmzalama Çerçevesi'ni ve imzalama ilkesi ile uygulama örneklerini açıklar. (12 yazdırılan sayfa)

İçindekiler

Giriş
OPC Dijital İmzalama Çerçevesi bileşenleri
   XML Dijital İmza Standardı
   Paketlerde Dijital İmzaları Temsil Etme
   İmzalama Bölümleri ve İlişkiler
Paket İmzaları için Programlama Desteği
   İmzalama Paketi Bölümleri ve İlişkileri
   Sertifikaları ve İmzaları Doğrulama
Uygulama İmzalama İlkesi
   XPS Belgeleri
   XPS İmzaları için Programlama Desteği
Başvurular

Giriş

Açık Paketleme Kuralları (OPC) tarafından belirtilen paketleme modeli paketleri, parçaları ve ilişkileri açıklar. Paketler, içeriği ve kaynakları barındıran bölümleri tutar. İlişkiler, paketi parçalara bağlamak ve paketteki çeşitli parçaları bağlamak için tanımlanır.

Bu makalede, paket bileşenlerine ve destekleyici hizmetlere genel bir bakış sağlayan OPC Dijital İmzalama Çerçevesi ve imzalama ilkesi ve uygulama örnekleri ele alınmaktadır.

İmzalama Çerçevesi, dijital imzaları temsil eden bir altyapı ve imza oluşturma ve doğrulama hizmetleri içerir. İmzalama Çerçevesi, W3C XML Dijital İmza standardının paket parçalarına ve ilişkilerine uygulanmasını sağlar.

İmzalama Çerçevesi'ni kullanarak, paket tabanlı biçimlerin sahipleri biçimlerine özgü "imzalama ilkelerini" tanımlar ve uygular. İlkeler, belirli biçimlerin integral içeriğinin nasıl imzalanıp doğrulanacağını belirtir ve imzaların farklı iş akışları için nasıl kullanıldığını kapsar. Aslında, tek bir biçim için bir belgenin yaşam döngüsünün farklı aşamalarında kullanılmak üzere tanımlanmış çeşitli ilkeler olabilir.

Paket tabanlı biçim için imzalama ilkesi, imzalama bölümleri ve ilişkileri ve muhtemelen diğer belge özellikleri (hedeflenen görüntüleme cihazının doğrulanması, renk derinliği veya uygulama sürümü gibi) açısından ifade edilir. İmzalama ilkesi, imzalanan belge bileşenlerini ve varsa hangilerinin imzasız bırakılıp bırakılmadığını belirtir. Örneğin, bir pakete yeni parça ve ilişkilerin eklenmesine izin vermek için bir imzalama ilkesi uygulanabilir veya bir pakete yeni parçalar veya imzalar eklendiğinde bir ilke imzanın geçersiz kılınmasına neden olabilir.

Bu makalede , Açık Paketleme Kuralları Belirtimi ve W3C Önerisi XML İmza söz dizimi ve işlemesi hakkında bilgi sahibi olduğunuz varsayılır.

OPC Dijital İmzalama Çerçevesi bileşenleri

XML Dijital İmza Standardı

Paketler için İmzalama Çerçevesi, W3C Önerisi XML İmza söz dizimi ve işlemesinde tanımlandığı gibi XML Dijital İmza Standardı'nı kullanır. Bu Öneri, dijital imzaları üretmek ve depolamak için XML söz dizimi ve işleme kurallarını belirtir.

Standart, herhangi bir tür dijital kaynağı imzalamak ve doğrulamak için xml imza öğesi türünü, şemasını ve uyumluluk gereksinimlerini tanımlar. Şema ayrıca kaynaklara başvurmak ve imzayla ilgili algoritmalar belirtmek için öğeleri tanımlar.

Dijital imzaların özellikleri

dijital imza, imzalanan içeriğin imzalandıktan sonra değişip değişmediğini belirlemek için kullanılabilir. İmza, iyi bilinen bir algoritmaya göre karma olarak oluşturulan ve oluşturulduğunda imzada depolanan bir içerik bildirimi içerir. İçeriğin değişip değişmediğini belirlemek için imzalanmış içeriğin karması yeniden oluşturulur ve imzada depolanan karmayla karşılaştırılır.

Dijital imza, içeriğin imzalayanını tanımlamak için de kullanılabilir. İmzalayanın kimliği, imzayla ilişkilendirilmiş bir sertifikayla temsil edilir. Sertifika imzaya eklenmiş veya başka bir yerde kullanılabilir.

Dijital imza bir belgeyi "kilitlemez" veya şifrelenmesini sağlamaz (zaten şifrelenmiş olsa da). İmzalandıktan sonra belge içeriği değişmeden kalır. Dijital imzalar, imzalanmış içeriğin istenmeyen tüketiciler tarafından görüntülenmesini engellemez.

Paketlerde Dijital İmzaları Temsil Etme

Uygulamalar, belirli bir parça ve ilişki yapılandırmasını kullanarak dijital imzaları bir pakete ekler.

İmzalama Çerçevesi, XML Dijital İmza standardı tarafından izin verilen paketleme ad alanındaki öğeleri ve öznitelikleri kullanır. Paketleme ad alanında tanımlanan imza öğeleri, standardı çelişkiye düşmeden genişleten pakete özgü özellikleri destekler. Eklemelerin özeti için OPC Belirtiminin "XML Dijital İmza Belirtiminde Yapılan Değişiklikler" bölümüne bakın.

İmzalama Çerçevesi için tanımlanan paket bölümleri Origin bölümü, XML İmzası bölümü ve Sertifika bölümü'lerdir. Her biri iyi tanımlanmış bir içerik türüne sahiptir. İyi tanımlanmış ilişki türleri, OPC Belirtiminin Ek H, "Standart Ad Alanları ve İçerik Türleri" bölümünde belirtildiği gibi bir paketteki imza bölümlerini bağlamak için kullanılır.

Dijital İmza Kaynak Bölümü

Dijital İmza Kaynağı bölümü, bir paketteki imzalarda gezinmek için başlangıç noktasıdır. Dijital İmza Kaynağı bölümü, Dijital İmza Kaynağı ilişkisi kullanılarak paket kökünden hedeflenmiştir. Kaynak bölümünden birden çok İmza parçası hedeflenebilir. Pakette imza yoksa, Kaynak bölümü mevcut olmaz.

Dijital İmza XML İmza Bölümü

Dijital İmza XML İmzası bölümleri, W3C Dijital İmza standartlarında ve paketleme ad alanında tanımlanan işaretlemeleri içerir. Parçalar, Dijital İmza ilişkisiyle Dijital İmza Kaynağı parça XML'sinden hedeflenir.

Dijital İmza Sertifikası Bölümü

İmzalayanı tanımlamak için gereken X.509 sertifikası, pakete yerleştirildiyse XML İmzası bölümüne eklenmiş veya ayrı bir Sertifika bölümünde depolanmış olabilir. İsteğe bağlı Sertifika bölümü, Dijital İmza Sertifikası ilişkisine sahip XML İmzası bölümünden hedeflenmiştir. Sertifika bölümü birden çok İmza bölümü arasında paylaşılabilir.

Özel İmza Bölümleri

İmzalama Çerçevesi tarafından özel (uygulamaya özgü) imza bölümlerine izin verilir, ancak işlenmez. XML imzası dışında bir imza biçimini tutan imza bölümü, özel bir içerik türü tarafından tanımlanmalıdır. Ayrıca, Dijital İmza Kaynağı bölümünden bölümü hedeflemek için özel ilişki türüne sahip bir ilişki kullanılmalıdır.

İmzalama Bölümleri ve İlişkiler

XML Dijital İmza standardı, bir paket için parça olan adreslenebilir kaynakların imzasına izin verir. İmzalama Çerçevesi parçaların imzasını etkinleştirir. Bir paketteki ilişkiler parçasında depolanan ilişkilerin tümü aynı anda imzalanabilir veya imzalama için ilişkilerin bir alt kümesi belirtilebilir.

Geçerli olarak imzalanmış bir paketteki bir bölümün amaçlandığı gibi kullanıldığından veya işlendiğinden emin olmak için, bir bölümün içerik türü ve bölüm içeriği imzalanır. İçerik türü adreslenebilir bir kaynak olmadığından, içerik türü değerini imzalamak için pakete özgü bir yaklaşım benimsilir. Paket imzalandığında, imzalanan her bölümün içerik türü, imzalı bölüme başvuran URI'nin sorgu bileşeninde depolanır. Paket kullanıldığında, OPC Dijital İmzalama Çerçevesi, bölümün içerik türünün bölüm imzalandığından beri değişmediğinden emin olmak için içerik türü değerini kullanır.

İlişkiler bölümü bir bütün olarak imzalandığında, o bölümde tanımlanan tüm ilişkiler imzalanır. İmza geçersiz kılınmadan paketin bazı içeriğinin değişmesine izin veren imzalama ilkelerini desteklemek için İmzalama Çerçevesi, belirtilen ilişkileri imzalamaya yönelik bir mekanizma sağlar. Belirtilen ilişkileri imzalamak için İmzalama Çerçevesi özel bir dönüşüm kullanır( İlişkiler Dönüşümü (bkz . Dönüştürme Algoritmaları).

İlişkiler Dönüşümü, yalnızca belirtilen ilişki kümesini içeren bir ilişki bölümü oluşturur. Elde edilen ilişkiler bölümü imzalama için ve imza doğrulama sırasında kullanılır.

Paket İmzaları için Programlama Desteği

Uygulamalar imzaları imzalamak ve doğrulamak için PackageDigitalSignatureManager .NET 3.0 sınıflarını kullanabilir. System.IO.Packaging ad alanında tanımlanan pakete özgü sınıflar, System.Security.Cryptography.Xml ad alanında tanımlanan Microsoft .NET 3.0 Framework'ün dijital imza sınıflarını kullanır.

PackageDigitalSignatureManager sınıfı, imza oluşturup doğrulamak ve imza altyapısını bir pakete yerleştirmek için kullanılır. İmza, PackageDigitalSignature sınıfını temel alan bir nesneyle temsil edilir.

İmzalama Paketi Bölümleri ve İlişkileri

Bir uygulama, imzalama ilkesine göre imza atacak parçaların ve ilişkilerin listesini tanımlar. Uygulama daha sonra packageDigitalSignatureManager.Sign() yöntemini çağırarak imzayı oluşturur ve imza altyapısını pakete ekler.

Aşağıdaki örnek kodda, ilişki bölümleri dışında paketteki tüm bölümlerin imzalanması, paket kökünden kaynaklanan tüm mevcut ilişkilerin imzalanması ve XML İmzası bölümünde imzalama için kullanılan sertifikanın katıştırılması gösterilmektedir. Örnek kod, başlangıçta pakette imza bulunmadığını varsayar ve doğrulama öncesinde yalnızca bir imza uygulanır.

İmzalama İşlemini Başlatma

Paketteki imzalarla çalışmaya başlamak için, önce aşağıda gösterildiği gibi bir PackageDigitalSignatureManager oluşturun.

    // Open the package.
    Package package = Package.Open(filename);

    // Create the PackageDigitalSignatureManager
      PackageDigitalSignatureManager dsm =
        new PackageDigitalSignatureManager(package);

Sertifika Ekleme Seçenekleri

Sertifika, imzanın kendisine eklenmiş bir dize olarak, paketin ayrı bir parçası olarak veya paketin dışındaki bir kaynak olarak temsil edilebilir. Sertifika pakete yerleştirilecekse, bir uygulama PackageDigitalSignature.CertificateOption özelliğinin ekleme seçenekleri kullanılarak sertifikanın nasıl kalıcı olacağını belirtir. PackageDigitalSignatureManager sınıfı oluşturulduktan sonra, sertifika için ekleme seçenekleri aşağıdaki örnek kodda gösterildiği gibi ayarlanır.

    //Specify that the certificate is embedded in the signature held
    //in the XML Signature part.

    //Certificate embedding options include:
    // InSignaturePart – Certificate is embedded in the signature.
    // InCertificatePart – Certificate is embedded in a 
    //                     separate certificate part

    dsm.CertificateOption =
        CertificateEmbeddingOption.InSignaturePart;

İmzalı Parçalar Listesi

İmzalanması gereken bölümlerin listesi, bölümleri ele alan URI'ler kullanılarak belirtilir. Bu örnekte, PackUriHelper.IsRelationshipPartUri() yöntemi kullanılarak filtrelenen ilişki bölümleri dışında paketteki tüm bölümler imzalanır.

    //Initialize a list to hold the part URIs to sign.

    System.Collections.Generic.List<Uri> partsToSign =
        new System.Collections.Generic.List<Uri>();

    //Add each part to the list, except relationships parts.
    foreach (PackagePart packagePart in package.GetParts())
    {
        if (!PackUriHelper.IsRelationshipPartUri(packagePart.Uri))
      partsToSign.Add(packagePart.Uri);
  }

İmzalı İlişkiler Listesi

tek tek ilişkiler İlişkiler Dönüşümü kullanılarak imzalı. İlişkilerin bu şekilde imzalanması, imza geçersiz kılınmadan pakete yeni ilişkilerin eklenmesini sağlar.

İmzalama sırasında kullanılacak PackageRelationshipSelector nesnelerinin listesi oluşturularak imzalama için ilişkiler seçilir. PackageRelationshipSelector nesneleri ilişki türüne göre grup olarak oluşturulabilir (Open Packaging Conventions'ın "Standart Ad Alanları ve İçerik Türleri" bölümünde tanımlandığı gibi) veya aşağıdaki örnekte olduğu gibi ilişki kimliği belirtilerek tek tek oluşturulabilir.

     //Create list of selectors for the list of relationships

     List<PackageRelationshipSelector> relationshipSelectors = 
          new List<PackageRelationshipSelector>();

     //Create one selector for each package-level relationship, based on id

  foreach (PackageRelationship relationship in package.GetRelationships())
            {
                relationshipSelectors.Add(new
                    PackageRelationshipSelector(relationship.sourceUri, 
                    PackageRelationshipSelectorType.Id, relationship.Id));
            }

PackageRelationshipSelectorType.Id ile PackageRelationshipSelector oluşturulurken, imza için benzersiz kimliği belirtilen ilişki seçilir. PackageRelationshipSelectorType.Type ile bir seçici oluştururken, belirtilen türdeki tüm ilişkiler imzalama için seçilir. Aynı türdeki ilişkiler daha sonra bir pakete eklenirse, imza geçersiz kılınacaktır.

Sertifika Nesnesi Oluşturma

İmzalamadan önce, System.Security.Cryptography.X509Certificates.X509Certificate2 türünde bir nesne örneği oluşturarak geçerli bir X.509 sertifikası alınır. Bu nesne, imzalama sırasında PackageDigitalSignatureManager.Sign() yöntemine geçirilir. Sertifika nesneleri oluşturma hakkında daha fazla bilgi için bkz . System.Security.Cryptography.X509Certificates ad alanı.

İmzayı Uygulama

İmzalanması gereken bölümlerin ve ilişkilerin listesini oluşturduktan ve sertifika nesnesini aldıktan sonra, uygulama PackageDigitalSignatureManager.Sign() yöntemini çağırır.

     //Sign package using components created above

     PackageDigitalSignature signature = dsm.Sign(partsToSign, 
          x509Certificate, relationshipSelectors);

     //After signing, close the package.
     //The signature will be persisted in the package.
     package.Close();

Sign() yöntemi çağrıldığında, karma oluşturulur ve imza bildiriminde depolanır ve imza bölümü oluşturulur. İmza altyapısı pakette zaten varsa, yeni imza bölümü eklenir (izin veriliyorsa). Altyapı henüz pakette yoksa , Sign() yöntemi altyapıyı oluşturur ve pakete yerleştirir.

Sertifikaları ve İmzaları Doğrulama

Uygulamalar bir sertifikayı veya imzayı doğrulayabilir. İmzayı doğrulamadan önce sertifika doğrulanmalıdır. PackageDigitalSignature paketindeki imzayı temsil eden nesne, paketteyse, bu imzayı oluşturmak için kullanılan sertifikayı döndüren bir "İmzalayan" özelliğine sahiptir. Sertifika pakete eklenmediyse, uygulama sertifikayı uygulama tarafından bilinen bir konumdan alır.

PackageDigitalSignatureManager.VerifyCertificate() yöntemi, alınan sertifikayı doğrulamak, sertifika yapısını, son kullanma tarihini ve zincir durumunu denetlemek için kullanılır. Zincir durumu hakkında daha fazla bilgi için .NET Framework Sınıf Kitaplığı'ndaki X509ChainStatusFlag Numaralandırması'na bakın.

Uygulama geliştiricileri, imzalama ilkelerini desteklemek için sertifika durumunu kullanabilir. Örneğin, bir uygulama yalnızca belirli tarihlerden sonra verilen sertifikaların kabul edilebilir olduğunu belirtebilir.

PackageDigitalSignatureManager.VerifySignatures() yöntemi, paketteki tüm imzaları doğrulamak için kullanılır. Bu yöntem yalnızca imzaları doğrular, imzalarla ilişkili sertifikaları doğrular.

Aşağıdaki örnek kod, imzalama örneklerinde pakete yerleştirilen sertifikayı ve imzayı doğrulamak için kullanılabilir. Örnek kod, pakete ek imza eklenmediğini varsayar.

    // Open the package.

    Package package = Package.Open(filename);

    // Create the PackageDigitalSignatureManager

    PackageDigitalSignatureManager dsm =
        new PackageDigitalSignatureManager(package);

    // Verify the collection of certificates in the package (one, in this case)

        foreach(PackageDigitalSignature signature in pdsm.Signatures)
        {
        if(PackageDigitalSignatureManager.VerifyCertificate(signature.Signer)
            != X509ChainStatusFlags.NoError)
              {
                // Application-specific code for error handling 
                // or certificate validation 
              }
        }
 
   // For this example, if all certificates are valid,
   // verify all signatures in the package.
 
    VerifyResult vResult = dsm.VerifySignatures(false);
    Console.WriteLine("Result " + vResult.ToString());

    // Close the package.

    package.Close();

Uygulama İmzalama İlkesi

Paket tabanlı biçimler kullanan uygulamalar, İmzalama Çerçevesi'nin bir parçası olarak kendi ilkelerini tanımlar. İlke, biçimin öğe türleri ve iş akışı gereksinimleri tarafından belirlenir. Bu bölümde, imzalama ilkesi bir Microsoft paket tabanlı biçim için açıklanmıştır: XPS Belgesi biçimi.

XPS Belgeleri

XPS Belgesi biçimi, XML Kağıt Belirtiminde belirtildiği gibi Açık Paketleme Kuralları'nı temel alır. XML Kağıt Belirtimi, XPS Belgelerini imzalama ilkesini tanımlar. Bu ilkenin içinde, uygulama özelliklerini veya iş akışını desteklemek için kullanılabilir imzalama seçenekleri vardır.

XPS Belge Paketleri için İmzalama İlkesi

XPS Belgeleri için imzalama ilkesi, içeriğin doğrulanabilmesi için imzalanması gereken parça ve ilişkiler kümesini açıklar. Bu ilkenin bir parçası olarak, bir uygulama isteğe bağlı olarak içeriğe ek olarak CoreProperties bölümü gibi belirli bölümlerin bir bileşimini içeren bir imza oluşturabilir. Bu bölümlerin imzalanmasının, imza geçersiz kılınmadan değiştirilmesi engellenir. Ayrıca, uygulamalar isteğe bağlı olarak imzadaki Dijital İmza Kaynağı bölümüne eklenmiş olan ilişkiler bölümünü imzalayarak, imzayı geçersiz hale getirmeden belgeye yeni imzaların eklenmesini engelleyebilir.

İmzanın geçerli olması için XPS Belgesi imzalama ilkesi, imzaya belirli bölümlerin ve ilişkilerin eklenmesini gerektirir. Tanınmayan hiçbir parça veya ilişki imzalanamaz. bir imzayı doğrularken, bir uygulamanın tüm gerekli bölümlerin ve ilişkilerin imzalandığını onaylaması gerekir.

xps belge bölümleri imzalayın

Aşağıdaki tabloda, tüm XPS belgelerinde imzalanması gereken bölümlerin listesi ve isteğe bağlı olarak imzalanan bölümler yer alır. İlişkiler için XPS imzalama ilkesi, gerekli ilişkilerin (gerekli bölümleri hedefleyen ilişkiler) her zaman OPC tanımlı İlişkiler Dönüşümü kullanılarak imzalandığını belirtir. Bir parça imzalıysa, onu hedefleyen ilişkiler de imzalanmalıdır.

Parça Türü İlke
FixedDocumentSequence bölümü İmzalanması gerekir
FixedDocument bölümü İmzalanması gerekir
DocumentStructure bölümleri İmzalanması gerekir
SignatureDefinitions bölümü İmzalanması gerekir
FixedPage bölümleri İmzalanması gerekir
Gerekli kaynak bölümleri (yazı tipleri, resimler gibi) İmzalanması gerekir
StoryFragments bölümleri İmzalanması gerekir
Küçük resim bölümleri İmzalanması gerekir
CoreProperties bölümü İsteğe bağlı olarak imzalı
Dijital İmza Kaynağı bölümü İsteğe bağlı olarak imzalı
Dijital İmza Sertifikası bölümü İsteğe bağlı olarak imzalı
PrintTicket parçaları İsteğe bağlı olarak imzalı
DiscardControl bölümleri İsteğe bağlı olarak imzalı

XPS imzalama ilkesi hakkında daha fazla bilgi için XML Kağıt Belirtimi'ndeki "XPS Belge Paketi Özellikleri: Dijital İmzalar: İmzalama Kuralları" bölümüne bakın.

İşaretlemeyi Uyumluluk İmzalama İlkesi

XML Kağıt Belirtimi, xps belgesine alternatif içerik eklemenin bir aracını açıklar: işaretleme uyumluluğu. Alternatif içerik, İşaretleme Uyumluluğu ad alanındaki öğelerin içine yerleştirilir. İlkeye göre, İşaretleme Uyumluluğu öğeleri ve özniteliklerine sahip XPS Belgeleri, imzalama uygulaması tüm içerik alternatiflerini eşdeğer olarak tanımadığı sürece geçerli olarak imzalanamaz. Yalnızca tanınan öğeleri ve öznitelikleri içeren XPS Belgeleri imzalanabilir veya doğrulanabilir.

Countersignatures

Bir XPS Belgesinin içeriğine birden fazla imza uygulanabilir. Örneğin, yasal bir sözleşmeyi temsil eden içerik, imzalanan içeriği ve imzalayanın kimliğini gösteren birkaç kişinin imzalarını uygulamasını gerektirebilir.

Yeni imza eklemek, dijital imza kaynağı bölümüne eklenen ilişkiler bölümünde her zaman yeni bir ilişki oluşturur. Varolan imzaları geçersiz hale getirmeden bir XPS Belgesine yeni imzalar eklemek için, bu ilişkiler bölümü imzasız kalmalıdır (ancak ilişkilerin bir alt kümesi imzalanabilir). İlişkiler bölümü bir imzaya dahil edilirse, bu imza daha sonra uygulanan tüm imzalar tarafından geçersiz kılınacaktır.

XPS İmzalarını Doğrulama

XPS imzalama ilkesi, imza oluşturmayı tanımlamaya ek olarak, imzanın geçerli olarak nasıl doğrulanması yapılacağını da belirtir. İlke, aşağıdaki tabloda gösterildiği gibi, bir imza için uyumsuz, bozuk, sorgulanabilir ve geçerli olan geçerlilik durumlarını tanımlar.

İmza Durumu Tüm gerekli parçalar ve ilişkiler imzalandı mı? İmza yalnızca tanınan içeriği mi içeriyor? İmzalı içeriğin karması doğrulandı mı? İmzalı İşaretlemeyi Uyumluluk içeriği tanındı mı? Sertifika geçerli mi?
Uyumsuz NO

YES

yok

NO

yok

yok

yok

yok

yok

yok

Kırık YES EVET NO yok yok
Şüpheli YES

YES

YES

YES

YES

EVET

NO

YES

yok

NO

Geçerli YES YES YES YES YES

XPS Görüntüleyicisi sorgulanabilir ve bozuk XPS imzalarının yanı sıra geçerli XPS imzalarını görüntüler. Uyumsuz imzalar numaralandırılmaz.

XPS İmzaları için Programlama Desteği

Bir XPS Belgesi ile çalışırken, uygulamalar XpsDigitalSignature sınıfındaki yöntemleri kullanabilir. Bu sınıf PackageDigitalSignature sınıfını temel alır ve XPS Dijital İmza Belirtiminde belirtilen algoritmaları ve gereksinimleri izleyen yöntemleri içerir. İmzalama ve doğrulama yöntemleri, bir XPS Belgesinin tüm gerekli bölümlerinin ve ilişkilerinin imzalandığını doğrular.

XPS Belgesi İmzalama

XPS Belgesini imzalamak için XpsDocument.SignDigitally() yöntemi kullanılır. yöntemini çağırmadan önce, bir uygulamanın System.Security.Cryptography.X509Certificates.X509Certificate2 nesnesi kullanılarak alınabilen bir X.509 sertifikasına sahip olması gerekir.

     // Open the XPS Document

     XpsDocument document = new XpsDocument(dstContainer,
          FileAccess.ReadWrite);

     // Obtain the certificate object from a file

     X509Certificate certificate =
          509Certificate.CreateFromCertFile(certFilename);

     // Create the signature and add it to the document using
     // the OPC Signing Framework

     document.SignDigitally(certificate, true, 
          XpsDigSigPartAlteringRestrictions.None);

XpsDigSigPartAlteringRestrictions , imzalama ilkesine göre imza için ek kısıtlamalar belirtmek için kullanılabilir. Bu parametre , CoreMetadata ve/veya SignatureOrigin bölümlerinin imzadan dışlanıp dışlanmayacağını belirtir. Dışlanan bölümler daha sonra imza geçersiz kılınmadan değiştirilebilir. Örneğin, CoreMetadata bölümünün imzadan dışlanması, bir uygulamanın imzayı geçersiz hale getirmeden bazı belge özelliklerini değiştirmesine olanak tanır.

PrintTicket ve DiscardControl bölümleri SignDigitally() yöntemi tarafından oluşturulan imzaların dışında tutulur, ancak bu parçalar isteğe bağlı olarak uygulamaya özgü bir şekilde imzalanabilir.

XPS Belge İmzasını Doğrulama

Bir veya birden çok imza bir XPS Belgesi ile depolanabilir. İmzalar XpsDocument.Signatures özelliğinden alınabilir. Her imza, XpsDigitalSignature nesnesinin bir örneğiyle temsil edilir.

Aşağıdaki örnekte yalnızca koleksiyondaki ilk imza doğrulanmıştır.

     // Open the XPS Document.

     // Obtain the first enumerated signature.

     foreach (XpsDigitalSignature digitalSignature in
              document.Signatures)
     { 
          // Verify the signature object, if present.

          if (digitalSignature.Verify() ==
     System.IO.Packaging.PackageDigitalSignature.VerifyResult.Success)
          {
         //Signature is valid
          }
     }

Başvurular