2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								//  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// SignedXmlTest.cs - NUnit Test Cases for SignedXml  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Author:  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//	Sebastien Pouliot  <sebastien@ximian.com>  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// (C) 2002, 2003 Motus Technologies Inc. (http://www.motus.com)  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Copyright (C) 2004-2005, 2008 Novell, Inc (http://www.novell.com)  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  
						 
					
						
							
								
									
										
										
										
											2017-11-28 19:36:51 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#if  ! MOBILE  
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System.Globalization ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System.IO ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System.Security.Cryptography ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System.Security.Cryptography.X509Certificates ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System.Security.Cryptography.Xml ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System.Text ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  System.Xml ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  NUnit.Framework ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								namespace  MonoTests.System.Security.Cryptography.Xml  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									public  class  SignedXmlEx  :  SignedXml  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// required to test protected GetPublicKey in SignedXml 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  AsymmetricAlgorithm  PublicGetPublicKey  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  base . GetPublicKey  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-07 13:16:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/// <summary> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// This class is for testing purposes only. It allows to reproduce an error 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// that happens when an unsupported signing key is being used 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// while computing a signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// </summary> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									internal  sealed  class  CustomAsymmetricAlgorithm  :  AsymmetricAlgorithm  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// <summary> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// This class is for testing purposes only. It allows to reproduce an error 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// that happens when the hash algorithm cannot be created. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// </summary> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									public  sealed  class  BadHashAlgorithmSignatureDescription  :  SignatureDescription  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  BadHashAlgorithmSignatureDescription  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyAlgorithm  =  RSA . Create  ( ) . GetType  ( ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DigestAlgorithm  =  SHA1 . Create  ( ) . GetType  ( ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											FormatterAlgorithm  =  typeof  ( RSAPKCS1SignatureFormatter ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DeformatterAlgorithm  =  typeof  ( RSAPKCS1SignatureDeformatter ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  override  HashAlgorithm  CreateDigest  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// <summary> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// This class is for testing purposes only. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// It represents a correctly defined custom signature description. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/// </summary> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									public  sealed  class  RsaPkcs1Sha512SignatureDescription  :  SignatureDescription  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  const  string  Sha512HashAlgorithm  =  "SHA512" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  RsaPkcs1Sha512SignatureDescription  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyAlgorithm  =  RSA . Create  ( ) . GetType  ( ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DigestAlgorithm  =  SHA512 . Create  ( ) . GetType  ( ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											FormatterAlgorithm  =  typeof  ( RSAPKCS1SignatureFormatter ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DeformatterAlgorithm  =  typeof  ( RSAPKCS1SignatureDeformatter ) . FullName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  override  AsymmetricSignatureFormatter  CreateFormatter  ( AsymmetricAlgorithm  key ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  formatter  =  new  RSAPKCS1SignatureFormatter  ( key ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											formatter . SetHashAlgorithm  ( Sha512HashAlgorithm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  formatter ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  override  AsymmetricSignatureDeformatter  CreateDeformatter  ( AsymmetricAlgorithm  key ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  deformatter  =  new  RSAPKCS1SignatureDeformatter  ( key ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											deformatter . SetHashAlgorithm  ( Sha512HashAlgorithm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  deformatter ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									[TestFixture]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									public  class  SignedXmlTest  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-07 13:16:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										private  const  string  XmlDsigNamespacePrefix  =  "ds" ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  const  string  signature  =  "<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" /><Reference URI=\"#MyObjectId\"><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>CTnnhjxUQHJmD+t1MjVXrOW+MCA=</DigestValue></Reference></SignedInfo><SignatureValue>dbFt6Zw3vR+Xh7LbM/vuifyFA7gPh/NlDM2Glz/SJBsveISieuTBpZlk/zavAeuXR/Nu0Ztt4OP4tCOg09a2RNlrTP0dhkeEfL1jTzpnVaLHuQbCiwOWCgbRif7Xt7N12FuiHYb3BltP/YyXS4E12NxlGlqnDiFA1v/mkK5+C1o=</SignatureValue><KeyInfo><KeyValue xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><RSAKeyValue><Modulus>hEfTJNa2idz2u+fSYDDG4Lx/xuk4aBbvOPVNqgc1l9Y8t7Pt+ZyF+kkF3uUl8Y0700BFGAsprnhwrWENK+PGdtvM5796ZKxCCa0ooKkofiT4355HqK26hpV8dvj38vq/rkJe1jHZgkTKa+c/0vjcYZOI/RT/IZv9JfXxVWLuLxk=</Modulus><Exponent>EQ==</Exponent></RSAKeyValue></KeyValue></KeyInfo><Object Id=\"MyObjectId\" xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><ObjectListTag xmlns=\"\" /></Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  StaticValues  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/TR/2001/REC-xml-c14n-20010315" ,  SignedXml . XmlDsigCanonicalizationUrl ,  "XmlDsigCanonicalizationUrl" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments" ,  SignedXml . XmlDsigCanonicalizationWithCommentsUrl ,  "XmlDsigCanonicalizationWithCommentsUrl" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/2000/09/xmldsig#dsa-sha1" ,  SignedXml . XmlDsigDSAUrl ,  "XmlDsigDSAUrl" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/2000/09/xmldsig#hmac-sha1" ,  SignedXml . XmlDsigHMACSHA1Url ,  "XmlDsigHMACSHA1Url" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/2000/09/xmldsig#minimal" ,  SignedXml . XmlDsigMinimalCanonicalizationUrl ,  "XmlDsigMinimalCanonicalizationUrl" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/2000/09/xmldsig#" ,  SignedXml . XmlDsigNamespaceUrl ,  "XmlDsigNamespaceUrl" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/2000/09/xmldsig#rsa-sha1" ,  SignedXml . XmlDsigRSASHA1Url ,  "XmlDsigRSASHA1Url" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "http://www.w3.org/2000/09/xmldsig#sha1" ,  SignedXml . XmlDsigSHA1Url ,  "XmlDsigSHA1Url" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  Constructor_Empty  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( signature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNodeList  xnl  =  doc . GetElementsByTagName  ( "Signature" ,  SignedXml . XmlDsigNamespaceUrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xel  =  ( XmlElement )  xnl  [ 0 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . LoadXml  ( xel ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sx . CheckSignature  ( ) ,  "CheckSignature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  Constructor_XmlDocument  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( signature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNodeList  xnl  =  doc . GetElementsByTagName  ( "Signature" ,  SignedXml . XmlDsigNamespaceUrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xel  =  ( XmlElement )  xnl  [ 0 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sx . CheckSignature  ( ) ,  "CheckSignature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Ignore ("2.0 throws a NullReferenceException - reported as FDBK25892")]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// http://lab.msdn.microsoft.com/ProductFeedback/viewfeedback.aspx?feedbackid=02dd9730-d1ad-4170-8c82-36858c55fbe2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (ArgumentNullException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  Constructor_XmlDocument_Null  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  Constructor_XmlElement  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( signature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNodeList  xnl  =  doc . GetElementsByTagName  ( "Signature" ,  SignedXml . XmlDsigNamespaceUrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xel  =  ( XmlElement )  xnl  [ 0 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . LoadXml  ( xel ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sx . CheckSignature  ( ) ,  "CheckSignature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  Constructor_XmlElement_WithoutLoadXml  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( signature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNodeList  xnl  =  doc . GetElementsByTagName  ( "Signature" ,  SignedXml . XmlDsigNamespaceUrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xel  =  ( XmlElement )  xnl  [ 0 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( ! sx . CheckSignature  ( ) ,  "!CheckSignature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// SignedXml (XmlElement) != SignedXml () + LoadXml (XmlElement) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (ArgumentNullException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  Constructor_XmlElement_Null  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xel  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( xel ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// sample from MSDN (url) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  SignedXml  MSDNSample  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create example data to sign. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  document  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNode  node  =  document . CreateNode  ( XmlNodeType . Element ,  "" ,  "MyElement" ,  "samples" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											node . InnerText  =  "This is some text" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											document . AppendChild  ( node ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create the SignedXml message. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create a data object to hold the data to sign. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DataObject  dataObject  =  new  DataObject  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											dataObject . Data  =  document . ChildNodes ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											dataObject . Id  =  "MyObjectId" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add the data object to the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddObject  ( dataObject ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create a reference to be able to package everything into the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// message. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . Uri  =  "#MyObjectId" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add it to the message. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  signedXml ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (CryptographicException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignatureMethodMismatch  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  MSDNSample  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											RSA  key  =  RSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SignedInfo . SignatureMethod  =  SignedXml . XmlDsigHMACSHA1Url ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add a KeyInfo. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  keyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											keyInfo . AddClause  ( new  RSAKeyValue  ( key ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . KeyInfo  =  keyInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNotNull  ( signedXml . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Compute the signature - causes unsupported algorithm by the key. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  AsymmetricRSASignature  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  MSDNSample  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											RSA  key  =  RSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add a KeyInfo. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  keyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											keyInfo . AddClause  ( new  RSAKeyValue  ( key ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . KeyInfo  =  keyInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( 1 ,  signedXml . KeyInfo . Count ,  "KeyInfo" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureLength ,  "SignatureLength" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureValue ,  "SignatureValue" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Compute the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											Assert . AreEqual  ( SignedXml . XmlDsigRSASHA256Url ,  signedXml . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( 128 ,  signedXml . SignatureValue . Length ,  "SignatureValue" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Get the XML representation of the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xmlSignature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// LAMESPEC: we must reload the signature or it won't work 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// MS framework throw a "malformed element" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  vrfy  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											vrfy . LoadXml  ( xmlSignature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// assert that we can verify our own signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( vrfy . CheckSignature  ( ) ,  "RSA-Compute/Verify" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-07 09:35:12 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										// The same as MSDNSample(), but adding a few attributes 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  SignedXml  MSDNSampleMixedCaseAttributes  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create example data to sign. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  document  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNode  node  =  document . CreateNode  ( XmlNodeType . Element ,  "" ,  "MyElement" ,  "samples" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											node . InnerText  =  "This is some text" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlAttribute  a1  =  document . CreateAttribute  ( "Aa" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlAttribute  a2  =  document . CreateAttribute  ( "Bb" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlAttribute  a3  =  document . CreateAttribute  ( "aa" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlAttribute  a4  =  document . CreateAttribute  ( "bb" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											a1 . Value  =  "one" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											a2 . Value  =  "two" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											a3 . Value  =  "three" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											a4 . Value  =  "four" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											node . Attributes . Append  ( a1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											node . Attributes . Append  ( a2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											node . Attributes . Append  ( a3 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											node . Attributes . Append  ( a4 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											document . AppendChild  ( node ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create the SignedXml message. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create a data object to hold the data to sign. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DataObject  dataObject  =  new  DataObject  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											dataObject . Data  =  document . ChildNodes ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											dataObject . Id  =  "MyObjectId" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add the data object to the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddObject  ( dataObject ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Create a reference to be able to package everything into the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// message. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . Uri  =  "#MyObjectId" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add it to the message. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  signedXml ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  string  AsymmetricRSAMixedCaseAttributes  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  MSDNSampleMixedCaseAttributes  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											RSA  key  =  RSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add a KeyInfo. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  keyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											keyInfo . AddClause  ( new  RSAKeyValue  ( key ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . KeyInfo  =  keyInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Compute the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Get the XML representation of the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xmlSignature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											StringWriter  sw  =  new  StringWriter  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlWriter  w  =  new  XmlTextWriter  ( sw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											xmlSignature . WriteTo  ( w ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  sw . ToString  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Example output from Windows for AsymmetricRSAMixedCaseAttributes() 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  const  string  AsymmetricRSAMixedCaseAttributesResult  =  "<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" /><Reference URI=\"#MyObjectId\"><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>0j1xLsePFtuRHfXEnVdTSLWtAm4=</DigestValue></Reference></SignedInfo><SignatureValue>hmrEBgns5Xx14aDhzqOyIh0qLNMUldtW8+fNPcvtD/2KtEhNZQGctnhs90CRa1NZ08TqzW2pUaEwmqvMAtF4v8KtWzC/zTuc1jH6nxQvQSQo0ABhuXdu7/hknZkXJ4yKBbdgbKjAsKfULwbWrP/PacLPoYfCO+wXSrt+wLMTTWU=</SignatureValue><KeyInfo><KeyValue><RSAKeyValue><Modulus>4h/rHDr54r6SZWk2IPCeHX7N+wR1za0VBLshuS6tq3RSWap4PY2BM8VdbKH2T9RzyZoiHufjng+1seUx430iMsXisOLUkPP+yGtMQOSZ3CQHAa+IYA+fplXipixI0rV1J1wJNXQm3HxXQqKWpIv5fkwBtj8o2k6CWMgPNgFCnxc=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue></KeyValue></KeyInfo><Object Id=\"MyObjectId\"><MyElement Aa=\"one\" Bb=\"two\" aa=\"three\" bb=\"four\" xmlns=\"samples\">This is some text</MyElement></Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  AsymmetricRSAMixedCaseAttributesVerifyWindows  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( AsymmetricRSAMixedCaseAttributesResult ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v1  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v1 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( v1 . CheckSignature  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  AsymmetricDSASignature  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  MSDNSample  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DSA  key  =  DSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Add a KeyInfo. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  keyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											keyInfo . AddClause  ( new  DSAKeyValue  ( key ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . KeyInfo  =  keyInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( 1 ,  signedXml . KeyInfo . Count ,  "KeyInfo" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureLength ,  "SignatureLength" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureValue ,  "SignatureValue" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Compute the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureLength ,  "SignatureLength" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( SignedXml . XmlDsigDSAUrl ,  signedXml . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( 40 ,  signedXml . SignatureValue . Length ,  "SignatureValue" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Get the XML representation of the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xmlSignature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// LAMESPEC: we must reload the signature or it won't work 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// MS framework throw a "malformed element" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  vrfy  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											vrfy . LoadXml  ( xmlSignature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// assert that we can verify our own signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( vrfy . CheckSignature  ( ) ,  "DSA-Compute/Verify" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SymmetricHMACSHA1Signature  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  MSDNSample  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Compute the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											byte [ ]  secretkey  =  Encoding . Default . GetBytes  ( "password" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											HMACSHA1  hmac  =  new  HMACSHA1  ( secretkey ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( 0 ,  signedXml . KeyInfo . Count ,  "KeyInfo" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureLength ,  "SignatureLength" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureValue ,  "SignatureValue" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( hmac ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( 0 ,  signedXml . KeyInfo . Count ,  "KeyInfo" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SignatureLength ,  "SignatureLength" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( SignedXml . XmlDsigHMACSHA1Url ,  signedXml . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( 20 ,  signedXml . SignatureValue . Length ,  "SignatureValue" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( signedXml . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Get the XML representation of the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xmlSignature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// LAMESPEC: we must reload the signature or it won't work 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// MS framework throw a "malformed element" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  vrfy  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											vrfy . LoadXml  ( xmlSignature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// assert that we can verify our own signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( vrfy . CheckSignature  ( hmac ) ,  "HMACSHA1-Compute/Verify" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (CryptographicException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SymmetricMACTripleDESSignature  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  MSDNSample  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Compute the signature. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											byte [ ]  secretkey  =  Encoding . Default . GetBytes  ( "password" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											MACTripleDES  hmac  =  new  MACTripleDES  ( secretkey ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( hmac ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Using empty constructor 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// LAMESPEC: The two other constructors don't seems to apply in verifying signatures 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  AsymmetricRSAVerify  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  value  =  "<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" /><Reference URI=\"#MyObjectId\"><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>/Vvq6sXEVbtZC8GwNtLQnGOy/VI=</DigestValue></Reference></SignedInfo><SignatureValue>A6XuE8Cy9iOffRXaW9b0+dUcMUJQnlmwLsiqtQnADbCtZXnXAaeJ6nGnQ4Mm0IGi0AJc7/2CoJReXl7iW4hltmFguG1e3nl0VxCyCTHKGOCo1u8R3K+B1rTaenFbSxs42EM7/D9KETsPlzfYfis36yM3PqatiCUOsoMsAiMGzlc=</SignatureValue><KeyInfo><KeyValue xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><RSAKeyValue><Modulus>tI8QYIpbG/m6JLyvP+S3X8mzcaAIayxomyTimSh9UCpEucRnGvLw0P73uStNpiF7wltTZA1HEsv+Ha39dY/0j/Wiy3RAodGDRNuKQao1wu34aNybZ673brbsbHFUfw/o7nlKD2xO84fbajBZmKtBBDy63NHt+QL+grSrREPfCTM=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue></KeyValue></KeyInfo><Object Id=\"MyObjectId\"><MyElement xmlns=\"samples\">This is some text</MyElement></Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( value ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v1  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v1 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( v1 . CheckSignature  ( ) ,  "RSA-CheckSignature()" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v2  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v2 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											AsymmetricAlgorithm  key  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											bool  vrfy  =  v2 . CheckSignatureReturningKey  ( out  key ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( vrfy ,  "RSA-CheckSignatureReturningKey()" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v3  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v3 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( v3 . CheckSignature  ( key ) ,  "RSA-CheckSignature(key)" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Using empty constructor 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// LAMESPEC: The two other constructors don't seems to apply in verifying signatures 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  AsymmetricDSAVerify  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  value  =  "<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#dsa-sha1\" /><Reference URI=\"#MyObjectId\"><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>/Vvq6sXEVbtZC8GwNtLQnGOy/VI=</DigestValue></Reference></SignedInfo><SignatureValue>BYz/qRGjGsN1yMFPxWa3awUZm1y4I/IxOQroMxkOteRGgk1HIwhRYw==</SignatureValue><KeyInfo><KeyValue xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><DSAKeyValue><P>iglVaZ+LsSL8Y0aDXmFMBwva3xHqIypr3l/LtqBH9ziV2Sh1M4JVasAiKqytWIWt/s/Uk8Ckf2tO2Ww1vsNi1NL+Kg9T7FE52sn380/rF0miwGkZeidzm74OWhykb3J+wCTXaIwOzAWI1yN7FoeoN7wzF12jjlSXAXeqPMlViqk=</P><Q>u4sowiJMHilNRojtdmIuQY2YnB8=</Q><G>SdnN7d+wn1n+HH4Hr8MIryIRYgcXdbZ5TH7jAnuWc1koqRc1AZfcYAZ6RDf+orx6Lzn055FTFiN+1NHQfGUtXJCWW0zz0FVV1NJux7WRj8vGTldjJ5ef0oCenkpwDjcIxWsZgVobve4GPoyN1sAc1scnkJB59oupibklmF4y72A=</G><Y>XejzS8Z51yfl0zbYnxSYYbHqreSLjNCoGPB/KjM1TOyV5sMjz0StKtGrFWryTWc7EgvFY7kUth4e04VKf9HbK8z/FifHTXj8+Tszbjzw8GfInnBwLN+vJgbpnjtypmiI5Bm2nLiRbfkdAHP+OrKtr/EauM9GQfYuaxm3/Vj8B84=</Y><J>vGwGg9wqwwWP9xsoPoXu6kHArJtadiNKe9azBiUx5Ob883gd5wlKfEcGuKkBmBySGbgwxyOsIBovd9Kk48hF01ymfQzAAuHR0EdJECSsTsTTKVTLQNBU32O+PRbLYpv4E8kt6rNL83JLJCBY</J><Seed>sqzn8J6fd2gtEyq6YOqiUSHgPE8=</Seed><PgenCounter>sQ==</PgenCounter></DSAKeyValue></KeyValue></KeyInfo><Object Id=\"MyObjectId\"><MyElement xmlns=\"samples\">This is some text</MyElement></Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( value ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v1  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v1 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( v1 . CheckSignature  ( ) ,  "DSA-CheckSignature()" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v2  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v2 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											AsymmetricAlgorithm  key  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											bool  vrfy  =  v2 . CheckSignatureReturningKey  ( out  key ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( vrfy ,  "DSA-CheckSignatureReturningKey()" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v3  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v3 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( v3 . CheckSignature  ( key ) ,  "DSA-CheckSignature(key)" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SymmetricHMACSHA1Verify  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  value  =  "<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#hmac-sha1\" /><Reference URI=\"#MyObjectId\"><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>/Vvq6sXEVbtZC8GwNtLQnGOy/VI=</DigestValue></Reference></SignedInfo><SignatureValue>e2RxYr5yGbvTqZLCFcgA2RAC0yE=</SignatureValue><Object Id=\"MyObjectId\"><MyElement xmlns=\"samples\">This is some text</MyElement></Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( value ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v1  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v1 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											byte [ ]  secretkey  =  Encoding . Default . GetBytes  ( "password" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											HMACSHA1  hmac  =  new  HMACSHA1  ( secretkey ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( v1 . CheckSignature  ( hmac ) ,  "HMACSHA1-CheckSignature(key)" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// adapted from http://bugzilla.ximian.com/show_bug.cgi?id=52084 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  GetIdElement  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( signature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  v1  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											v1 . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( v1 . CheckSignature  ( ) ,  "CheckSignature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xel  =  v1 . GetIdElement  ( doc ,  "MyObjectId" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( xel . InnerXml . StartsWith  ( "<ObjectListTag" ) ,  "GetIdElement" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  GetPublicKey  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( signature ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXmlEx  sxe  =  new  SignedXmlEx  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sxe . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											AsymmetricAlgorithm  aa1  =  sxe . PublicGetPublicKey  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( ( aa1  is  RSA ) ,  "First Public Key is RSA" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											AsymmetricAlgorithm  aa2  =  sxe . PublicGetPublicKey  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( aa2 ,  "Second Public Key is null" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// [ExpectedException (typeof (ArgumentNullException))] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  AddObject_Null  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// still no ArgumentNullExceptions for this one 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . AddObject  ( null ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (ArgumentNullException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  AddReference_Null  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . AddReference  ( null ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (CryptographicException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  GetXml_WithoutInfo  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xel  =  sx . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (ArgumentNullException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  LoadXml_Null  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . LoadXml  ( null ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SigningKeyName  ( )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXmlEx  sxe  =  new  SignedXmlEx  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsNull  ( sxe . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sxe . SigningKeyName  =  "mono" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "mono" ,  sxe . SigningKeyName ,  "SigningKeyName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  CheckSignatureEmptySafe  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfoClause  kic ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  ki ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// empty keyinfo passes... 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . KeyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( ! sx . CheckSignature  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// with empty KeyInfoName 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											kic  =  new  KeyInfoName  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ki  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											ki . AddClause  ( kic ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sx . KeyInfo  =  ki ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( ! sx . CheckSignature  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  CheckSignatureEmpty  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sx  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( ! sx . CheckSignature  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (CryptographicException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignatureNoSigningKey  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( "<foo/>" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . Uri  =  "" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigEnvelopedSignatureTransform  env  =  new  XmlDsigEnvelopedSignatureTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( env ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[ExpectedException (typeof (CryptographicException))]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignatureMissingReferencedObject  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( "<foo/>" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DSA  key  =  DSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . Uri  =  "#bleh" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigEnvelopedSignatureTransform  env  =  new  XmlDsigEnvelopedSignatureTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( env ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  DataReferenceToNonDataObject  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											doc . LoadXml  ( "<foo Id='test'/>" ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DSA  key  =  DSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											reference . Uri  =  "#test" ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigC14NTransform  t  =  new  XmlDsigC14NTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( t ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignElementWithoutPrefixedNamespace  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  input  =  "<Action xmlns='urn:foo'>http://tempuri.org/IFoo/Echo</Action>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  expected  =  @"<Signature xmlns=""http://www.w3.org/2000/09/xmldsig#""><SignedInfo><CanonicalizationMethod Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-20010315"" /><SignatureMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#hmac-sha1"" /><Reference URI=""#_1""><Transforms><Transform Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-20010315"" /></Transforms><DigestMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#sha1"" /><DigestValue>zdFEZB8rNzvpNG/gFEJBWk/M5Nk=</DigestValue></Reference></SignedInfo><SignatureValue>+OyGVzrHjmKSDWLNyvgx8pjbPfM=</SignatureValue><Object Id=""_1""><Action xmlns=""urn:foo"">http://tempuri.org/IFoo/Echo</Action></Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											byte  [ ]  key  =  Convert . FromBase64String  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"1W5EigVnbnRjGLbg99ElieOmuUgYO+KcwMJtE35SAGI=" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Transform  t  =  new  XmlDsigC14NTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( expected ,  SignWithHMACSHA1  ( input ,  key ,  t ) ,  "#1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// The second result should be still identical. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( expected ,  SignWithHMACSHA1  ( input ,  key ,  t ) ,  "#2" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignElementWithPrefixedNamespace  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  input  =  "<a:Action xmlns:a='urn:foo'>http://tempuri.org/IFoo/Echo</a:Action>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  expected  =  @"<Signature xmlns=""http://www.w3.org/2000/09/xmldsig#""><SignedInfo><CanonicalizationMethod Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-20010315"" /><SignatureMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#hmac-sha1"" /><Reference URI=""#_1""><Transforms><Transform Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-20010315"" /></Transforms><DigestMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#sha1"" /><DigestValue>6i5FlqkEfJOdUaOMCK7xn0I0HDg=</DigestValue></Reference></SignedInfo><SignatureValue>tASp+e2A0xqcm02jKg5TGqlhKpI=</SignatureValue><Object Id=""_1""><a:Action xmlns:a=""urn:foo"">http://tempuri.org/IFoo/Echo</a:Action></Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											byte  [ ]  key  =  Convert . FromBase64String  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"1W5EigVnbnRjGLbg99ElieOmuUgYO+KcwMJtE35SAGI=" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( SignWithHMACSHA1  ( input ,  key ) ,  expected ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										string  SignWithHMACSHA1  ( string  input ,  byte  [ ]  key ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  SignWithHMACSHA1  ( input ,  key ,  new  XmlDsigC14NTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										string  SignWithHMACSHA1  ( string  input ,  byte  [ ]  key ,  Transform  transform ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( input ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sxml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											HMACSHA1  keyhash  =  new  HMACSHA1  ( key ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											DataObject  d  =  new  DataObject  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											//d.Data = doc.SelectNodes ("//*[local-name()='Body']/*"); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											d . Data  =  doc . SelectNodes  ( "//*[local-name()='Action']" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											d . Id  =  "_1" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sxml . AddObject  ( d ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  r  =  new  Reference  ( "#_1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											r . AddTransform  ( transform ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											r . DigestMethod  =  SignedXml . XmlDsigSHA1Url ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sxml . SignedInfo . AddReference  ( r ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sxml . ComputeSignature  ( keyhash ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											StringWriter  sw  =  new  StringWriter  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlWriter  w  =  new  XmlTextWriter  ( sw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sxml . GetXml  ( ) . WriteTo  ( w ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											w . Close  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  sw . ToString  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										[TestCase (null, TestName = "null")]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[TestCase ("", TestName = "empty")]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  GetIdElement_WhenElementNameMustBeNonColonizedAndItIsNotProvided_ThrowsArgumentNullException  ( string  elementName ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  sut  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  ex  =  Assert . Throws < ArgumentNullException >  ( ( )  = >  sut . GetIdElement  ( new  XmlDocument  ( ) ,  elementName ) ,  "Exception" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( ex . ParamName ,  Is . EqualTo  ( "name" ) ,  "ParamName" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										public  void  GetIdElement_WhenElementNameMustBeNonColonizedAndItContainsColon_ReturnsNull  ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											var  sut  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( sut . GetIdElement  ( new  XmlDocument  ( ) ,  "t:test" ) ,  Is . Null ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  GetIdElement_WhenXmlDocumentIsNotProvided_ReturnsNull  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  sut  =  new  SignedXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( sut . GetIdElement  ( null ,  "value" ) ,  Is . Null ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Category ("NotWorking")]  // bug #79483  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  DigestValue_CRLF  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  CreateSomeXml  ( "\r\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigExcC14NTransform  transform  =  new  XmlDsigExcC14NTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											transform . LoadInput  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Stream  s  =  ( Stream )  transform . GetOutput  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  output  =  Stream2String  ( s ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "<person>
\n  <birthplace>Brussels</birthplace>
\n</person>" ,  output ,  "#1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											s . Position  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											HashAlgorithm  hash  =  HashAlgorithm . Create  ( "System.Security.Cryptography.SHA1CryptoServiceProvider" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											byte [ ]  digest  =  hash . ComputeHash  ( s ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "IKbfdK2/DMfXyezCf5QggVCXfk8=" ,  Convert . ToBase64String  ( digest ) ,  "#2" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											X509Certificate2  cert  =  new  X509Certificate2  ( _pkcs12 ,  "mono" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  cert . PrivateKey ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SignedInfo . CanonicalizationMethod  =  SignedXml . XmlDsigExcC14NTransformUrl ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . Uri  =  "" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigEnvelopedSignatureTransform  env  =  new  XmlDsigEnvelopedSignatureTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( env ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  keyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfoX509Data  x509KeyInfo  =  new  KeyInfoX509Data  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											x509KeyInfo . AddCertificate  ( new  X509Certificate2  ( _cert ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											x509KeyInfo . AddCertificate  ( cert ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											keyInfo . AddClause  ( x509KeyInfo ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . KeyInfo  =  keyInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											digest  =  reference . DigestValue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "e3dsi1xK8FAx1vsug7J203JbEAU=" ,  Convert . ToBase64String  ( digest ) ,  "#3" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "<SignedInfo xmlns=\"http://www.w3.org/2000/09/xmldsig#\">"  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<Reference URI=\"\">" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<Transforms>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "</Transforms>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<DigestValue>e3dsi1xK8FAx1vsug7J203JbEAU=</DigestValue>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "</Reference>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "</SignedInfo>" ,  signedXml . SignedInfo . GetXml  ( ) . OuterXml ,  "#4" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  DigestValue_LF  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  CreateSomeXml  ( "\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigExcC14NTransform  transform  =  new  XmlDsigExcC14NTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											transform . LoadInput  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Stream  s  =  ( Stream )  transform . GetOutput  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  output  =  Stream2String  ( s ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "<person>\n  <birthplace>Brussels</birthplace>\n</person>" ,  output ,  "#1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											s . Position  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											HashAlgorithm  hash  =  HashAlgorithm . Create  ( "System.Security.Cryptography.SHA1CryptoServiceProvider" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											byte [ ]  digest  =  hash . ComputeHash  ( s ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "e3dsi1xK8FAx1vsug7J203JbEAU=" ,  Convert . ToBase64String  ( digest ) ,  "#2" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											X509Certificate2  cert  =  new  X509Certificate2  ( _pkcs12 ,  "mono" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  cert . PrivateKey ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SignedInfo . CanonicalizationMethod  =  SignedXml . XmlDsigExcC14NTransformUrl ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											signedXml . SignedInfo . SignatureMethod  =  SignedXml . XmlDsigRSASHA1Url ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-10-19 20:04:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											reference . DigestMethod  =  SignedXml . XmlDsigSHA1Url ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											reference . Uri  =  "" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigEnvelopedSignatureTransform  env  =  new  XmlDsigEnvelopedSignatureTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( env ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  keyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfoX509Data  x509KeyInfo  =  new  KeyInfoX509Data  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											x509KeyInfo . AddCertificate  ( new  X509Certificate2  ( _cert ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											x509KeyInfo . AddCertificate  ( cert ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											keyInfo . AddClause  ( x509KeyInfo ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . KeyInfo  =  keyInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											digest  =  reference . DigestValue ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "e3dsi1xK8FAx1vsug7J203JbEAU=" ,  Convert . ToBase64String  ( digest ) ,  "#3" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( "<SignedInfo xmlns=\"http://www.w3.org/2000/09/xmldsig#\">"  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<Reference URI=\"\">" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<Transforms>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "</Transforms>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" />" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "<DigestValue>e3dsi1xK8FAx1vsug7J203JbEAU=</DigestValue>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "</Reference>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												+  "</SignedInfo>" ,  signedXml . SignedInfo . GetXml  ( ) . OuterXml ,  "#4" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Category ("NotWorking")]  // bug #79483  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignedXML_CRLF_Invalid  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											X509Certificate2  cert  =  new  X509Certificate2  ( _pkcs12 ,  "mono" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( string . Format  ( CultureInfo . InvariantCulture , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<person>{0}"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"  <birthplace>Brussels</birthplace>{0}"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\">"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignedInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Reference URI=\"\">"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Transforms>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Transforms>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<DigestValue>IKbfdK2/DMfXyezCf5QggVCXfk8=</DigestValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Reference>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</SignedInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignatureValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"JuSd68PyARsZqGKSo5xX5yYHDuu6whHEhoXqxxFmGeEdvkKY2bgroWJ1ZTGHGr"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"VI7mtG3h0w1ibOKdltm9j4lZaZWo87CAJiJ2syeLbMyIVSw6OyZEsiFF/VqLKK"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"4T4AO6q7HYsC55zJrOvL1j9IIr8zBnJfvBdKckf0lczYbXc="  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</SignatureValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<KeyInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Data>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"MIIBozCCAQygAwIBAgIQHc+8iURSTUarmg4trmrnGTANBgkqhkiG9w0BAQUFAD"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ARMQ8wDQYDVQQDEwZOb3ZlbGwwIBcNMDYwOTIxMDcyNjUxWhgPMjA5MDAxMjEw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ODI2NTFaMA8xDTALBgNVBAMTBE1vbm8wgZ0wDQYJKoZIhvcNAQEBBQADgYsAMI"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"GHAoGBAJhFB1KHv2WzsHqih9Mvm3KffEOSMv+sh1mPW3sWI/95VOOVqJnhemMM"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"s82phSbNZeoPHny4btbykbRRaRQv94rtIM6geJR1e2c5mfJWtHSq3EYQarHC68"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"cAZvCAmQZGa1eQRNRqcTSKX8yfqH0SouIE9ohJtpiluNe+Xgk5fKv3AgERMA0G"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"CSqGSIb3DQEBBQUAA4GBAE6pqSgK8QKRHSh6YvYs9oRh1n8iREco7QmZCFj7UB"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"kn/QgJ9mKsT8o12VnYHqBCEwBNaT1ay3z/SR4/Z383zuu4Y6xxjqOqnM6gtwUV"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"u5/0hvz+ThtuTjItG6Ny5JkLZZQt/XbI5kg920t9jq3vbHBMuX2HxivwQe5sug"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"jPaTEY"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"MIIBpTCCAQ6gAwIBAgIQXo6Lr3rrSkW4xmNPRbHMbjANBgkqhkiG9w0BAQUFAD"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ARMQ8wDQYDVQQDEwZOb3ZlbGwwIBcNMDYwOTIxMDcxNDE4WhgPMjA5MDAxMjEw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ODE0MThaMBExDzANBgNVBAMTBk1pZ3VlbDCBnTANBgkqhkiG9w0BAQEFAAOBiw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"AwgYcCgYEArCkeSZ6U3U3Fm2qSuQsM7xvvsSzZGQLPDUHFQ/BZxA7LiGRfXbmO"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"yPkkYRYItXdy0yDl/8rAjelaL8jQ4me6Uexyeq+5xEgHn9VbNJny5apGNi4kF1"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"8DR5DK9Zme9d6icusgW8krv3//5SVE8ao7X5qrIOGS825eCJL73YWbxKkCAREw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"DQYJKoZIhvcNAQEFBQADgYEASqBgYTkIJpDO28ZEXnF5Q/G3xDR/MxhdcrCISJ"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"tDbuGVZzK+xhFhiYD5Q1NiGhD4oDIVJPwKmZH4L3YP96iSh6RdtO27V05ET/X5"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"yWMKdeIsq6r9jXXv7NaWTmvNfMLKLNgEBCJ00+wN0u4xHUC7yCJc0KNQ3fjDLU"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"AT1oaVjWI="  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Data>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</KeyInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Signature>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</person>" ,  "\r\n" ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNodeList  nodeList  =  doc . GetElementsByTagName  ( "Signature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . LoadXml  ( ( XmlElement )  nodeList  [ 0 ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( ! signedXml . CheckSignature  ( ) ,  "#2" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Category ("NotWorking")]  // bug #79483  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignedXML_CRLF_Valid  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											X509Certificate2  cert  =  new  X509Certificate2  ( _pkcs12 ,  "mono" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  CreateSignedXml  ( cert ,  SignedXml . XmlDsigExcC14NTransformUrl ,  "\r\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( string . Format  ( CultureInfo . InvariantCulture ,  "<person>{0}"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"  <birthplace>Brussels</birthplace>{0}"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\">"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignedInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Reference URI=\"\">"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Transforms>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Transforms>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<DigestValue>e3dsi1xK8FAx1vsug7J203JbEAU=</DigestValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Reference>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</SignedInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignatureValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"X29nbkOR/Xk3KwsEpEvpDOqfI6/NTtiewIxNqKMrPCoM0HLawK5HKsCw3lL07C"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"8SwqvoXJL9VS05gsSia85YCB8NPDeHuHY3CPGT7DVpgeHFA0oefMnOi8IAqKD2"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"nx29A222u5OmwbDO0qFqbtsgvIFiP5YJg04cwmnqs+eL+WA="  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</SignatureValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<KeyInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Data>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"MIIBozCCAQygAwIBAgIQHc+8iURSTUarmg4trmrnGTANBgkqhkiG9w0BAQUFAD"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ARMQ8wDQYDVQQDEwZOb3ZlbGwwIBcNMDYwOTIxMDcyNjUxWhgPMjA5MDAxMjEw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ODI2NTFaMA8xDTALBgNVBAMTBE1vbm8wgZ0wDQYJKoZIhvcNAQEBBQADgYsAMI"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"GHAoGBAJhFB1KHv2WzsHqih9Mvm3KffEOSMv+sh1mPW3sWI/95VOOVqJnhemMM"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"s82phSbNZeoPHny4btbykbRRaRQv94rtIM6geJR1e2c5mfJWtHSq3EYQarHC68"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"cAZvCAmQZGa1eQRNRqcTSKX8yfqH0SouIE9ohJtpiluNe+Xgk5fKv3AgERMA0G"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"CSqGSIb3DQEBBQUAA4GBAE6pqSgK8QKRHSh6YvYs9oRh1n8iREco7QmZCFj7UB"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"kn/QgJ9mKsT8o12VnYHqBCEwBNaT1ay3z/SR4/Z383zuu4Y6xxjqOqnM6gtwUV"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"u5/0hvz+ThtuTjItG6Ny5JkLZZQt/XbI5kg920t9jq3vbHBMuX2HxivwQe5sug"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"jPaTEY"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"MIIBpTCCAQ6gAwIBAgIQXo6Lr3rrSkW4xmNPRbHMbjANBgkqhkiG9w0BAQUFAD"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ARMQ8wDQYDVQQDEwZOb3ZlbGwwIBcNMDYwOTIxMDcxNDE4WhgPMjA5MDAxMjEw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ODE0MThaMBExDzANBgNVBAMTBk1pZ3VlbDCBnTANBgkqhkiG9w0BAQEFAAOBiw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"AwgYcCgYEArCkeSZ6U3U3Fm2qSuQsM7xvvsSzZGQLPDUHFQ/BZxA7LiGRfXbmO"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"yPkkYRYItXdy0yDl/8rAjelaL8jQ4me6Uexyeq+5xEgHn9VbNJny5apGNi4kF1"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"8DR5DK9Zme9d6icusgW8krv3//5SVE8ao7X5qrIOGS825eCJL73YWbxKkCAREw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"DQYJKoZIhvcNAQEFBQADgYEASqBgYTkIJpDO28ZEXnF5Q/G3xDR/MxhdcrCISJ"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"tDbuGVZzK+xhFhiYD5Q1NiGhD4oDIVJPwKmZH4L3YP96iSh6RdtO27V05ET/X5"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"yWMKdeIsq6r9jXXv7NaWTmvNfMLKLNgEBCJ00+wN0u4xHUC7yCJc0KNQ3fjDLU"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"AT1oaVjWI="  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Data>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</KeyInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Signature>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</person>" ,  "\r\n" ) ,  doc . OuterXml ,  "#1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Ignore ("This is a bad test case which should basically just check the computed signature value instead of comparing XML document literal string, and thus caused inconsistency between .NET 1.1 and .NET 2.0. Not deleting this test case, to easily find the reason for potentially happening regression in the future (which should not waste time).")]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignedXML_LF_Valid  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											X509Certificate2  cert  =  new  X509Certificate2  ( _pkcs12 ,  "mono" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  CreateSignedXml  ( cert ,  SignedXml . XmlDsigExcC14NTransformUrl ,  "\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( string . Format  ( CultureInfo . InvariantCulture ,  "<person>{0}"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"  <birthplace>Brussels</birthplace>{0}"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\">"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignedInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<CanonicalizationMethod Algorithm=\"http://www.w3.org/2001/10/xml-exc-c14n#\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#rsa-sha1\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Reference URI=\"\">"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Transforms>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Transforms>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" />"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<DigestValue>e3dsi1xK8FAx1vsug7J203JbEAU=</DigestValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Reference>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</SignedInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<SignatureValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"X29nbkOR/Xk3KwsEpEvpDOqfI6/NTtiewIxNqKMrPCoM0HLawK5HKsCw3lL07C"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"8SwqvoXJL9VS05gsSia85YCB8NPDeHuHY3CPGT7DVpgeHFA0oefMnOi8IAqKD2"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"nx29A222u5OmwbDO0qFqbtsgvIFiP5YJg04cwmnqs+eL+WA="  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</SignatureValue>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<KeyInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Data>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"MIIBozCCAQygAwIBAgIQHc+8iURSTUarmg4trmrnGTANBgkqhkiG9w0BAQUFAD"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ARMQ8wDQYDVQQDEwZOb3ZlbGwwIBcNMDYwOTIxMDcyNjUxWhgPMjA5MDAxMjEw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ODI2NTFaMA8xDTALBgNVBAMTBE1vbm8wgZ0wDQYJKoZIhvcNAQEBBQADgYsAMI"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"GHAoGBAJhFB1KHv2WzsHqih9Mvm3KffEOSMv+sh1mPW3sWI/95VOOVqJnhemMM"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"s82phSbNZeoPHny4btbykbRRaRQv94rtIM6geJR1e2c5mfJWtHSq3EYQarHC68"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"cAZvCAmQZGa1eQRNRqcTSKX8yfqH0SouIE9ohJtpiluNe+Xgk5fKv3AgERMA0G"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"CSqGSIb3DQEBBQUAA4GBAE6pqSgK8QKRHSh6YvYs9oRh1n8iREco7QmZCFj7UB"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"kn/QgJ9mKsT8o12VnYHqBCEwBNaT1ay3z/SR4/Z383zuu4Y6xxjqOqnM6gtwUV"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"u5/0hvz+ThtuTjItG6Ny5JkLZZQt/XbI5kg920t9jq3vbHBMuX2HxivwQe5sug"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"jPaTEY"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"<X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"MIIBpTCCAQ6gAwIBAgIQXo6Lr3rrSkW4xmNPRbHMbjANBgkqhkiG9w0BAQUFAD"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ARMQ8wDQYDVQQDEwZOb3ZlbGwwIBcNMDYwOTIxMDcxNDE4WhgPMjA5MDAxMjEw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"ODE0MThaMBExDzANBgNVBAMTBk1pZ3VlbDCBnTANBgkqhkiG9w0BAQEFAAOBiw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"AwgYcCgYEArCkeSZ6U3U3Fm2qSuQsM7xvvsSzZGQLPDUHFQ/BZxA7LiGRfXbmO"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"yPkkYRYItXdy0yDl/8rAjelaL8jQ4me6Uexyeq+5xEgHn9VbNJny5apGNi4kF1"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"8DR5DK9Zme9d6icusgW8krv3//5SVE8ao7X5qrIOGS825eCJL73YWbxKkCAREw"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"DQYJKoZIhvcNAQEFBQADgYEASqBgYTkIJpDO28ZEXnF5Q/G3xDR/MxhdcrCISJ"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"tDbuGVZzK+xhFhiYD5Q1NiGhD4oDIVJPwKmZH4L3YP96iSh6RdtO27V05ET/X5"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"yWMKdeIsq6r9jXXv7NaWTmvNfMLKLNgEBCJ00+wN0u4xHUC7yCJc0KNQ3fjDLU"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"AT1oaVjWI="  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Certificate>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</X509Data>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</KeyInfo>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</Signature>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												"</person>" ,  "\n" ) ,  doc . OuterXml ,  "#1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  // part of bug #79454  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  MultipleX509Certificates  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											X509Certificate2  cert  =  new  X509Certificate2  ( _pkcs12 ,  "mono" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc  =  CreateSignedXml  ( cert ,  SignedXml . XmlDsigExcC14NTransformUrl ,  "\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( VerifySignedXml  ( doc ) ,  "#1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc  =  CreateSignedXml  ( cert ,  SignedXml . XmlDsigExcC14NWithCommentsTransformUrl ,  "\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( VerifySignedXml  ( doc ) ,  "#2" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc  =  CreateSignedXml  ( cert ,  SignedXml . XmlDsigCanonicalizationUrl ,  "\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( VerifySignedXml  ( doc ) ,  "#3" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc  =  CreateSignedXml  ( cert ,  SignedXml . XmlDsigCanonicalizationWithCommentsUrl ,  "\n" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( VerifySignedXml  ( doc ) ,  "#4" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// creates a signed XML document with two certificates in the X509Data  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// element, with the second being the one that should be used to verify 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// the signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										static  XmlDocument  CreateSignedXml  ( X509Certificate2  cert ,  string  canonicalizationMethod ,  string  lineFeed ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  CreateSomeXml  ( lineFeed ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  cert . PrivateKey ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SignedInfo . CanonicalizationMethod  =  canonicalizationMethod ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  reference  =  new  Reference  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . Uri  =  "" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDsigEnvelopedSignatureTransform  env  =  new  XmlDsigEnvelopedSignatureTransform  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( env ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfo  keyInfo  =  new  KeyInfo  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											KeyInfoX509Data  x509KeyInfo  =  new  KeyInfoX509Data  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											x509KeyInfo . AddCertificate  ( new  X509Certificate2  ( _cert ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											x509KeyInfo . AddCertificate  ( cert ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											keyInfo . AddClause  ( x509KeyInfo ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . KeyInfo  =  keyInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlElement  xmlDigitalSignature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . DocumentElement . AppendChild  ( doc . ImportNode  ( xmlDigitalSignature ,  true ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  doc ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										static  bool  VerifySignedXml  ( XmlDocument  signedDoc ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  signedXml  =  new  SignedXml  ( signedDoc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlNodeList  nodeList  =  signedDoc . GetElementsByTagName  ( "Signature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . LoadXml  ( ( XmlElement )  nodeList  [ 0 ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  signedXml . CheckSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										static  XmlDocument  CreateSomeXml  ( string  lineFeed ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											StringWriter  sw  =  new  StringWriter  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sw . NewLine  =  lineFeed ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlTextWriter  xtw  =  new  XmlTextWriter  ( sw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											xtw . Formatting  =  Formatting . Indented ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											xtw . WriteStartElement  ( "person" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											xtw . WriteElementString  ( "birthplace" ,  "Brussels" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											xtw . WriteEndElement  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											xtw . Flush  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . PreserveWhitespace  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . Load  ( new  StringReader  ( sw . ToString  ( ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  doc ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										string  Stream2String  ( Stream  s ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											StringBuilder  sb  =  new  StringBuilder  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											int  b  =  s . ReadByte  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											while  ( b  ! =  - 1 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												sb . Append  ( Convert . ToChar  ( b ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												b  =  s . ReadByte  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  sb . ToString  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  static  byte  [ ]  _cert  =  new  byte  [ ]  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x30 ,  0x82 ,  0x01 ,  0xa3 ,  0x30 ,  0x82 ,  0x01 ,  0x0c ,  0xa0 ,  0x03 ,  0x02 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x01 ,  0x02 ,  0x02 ,  0x10 ,  0x1d ,  0xcf ,  0xbc ,  0x89 ,  0x44 ,  0x52 ,  0x4d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x46 ,  0xab ,  0x9a ,  0x0e ,  0x2d ,  0xae ,  0x6a ,  0xe7 ,  0x19 ,  0x30 ,  0x0d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x06 ,  0x09 ,  0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x01 ,  0x05 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x05 ,  0x00 ,  0x30 ,  0x11 ,  0x31 ,  0x0f ,  0x30 ,  0x0d ,  0x06 ,  0x03 ,  0x55 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x04 ,  0x03 ,  0x13 ,  0x06 ,  0x4e ,  0x6f ,  0x76 ,  0x65 ,  0x6c ,  0x6c ,  0x30 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x20 ,  0x17 ,  0x0d ,  0x30 ,  0x36 ,  0x30 ,  0x39 ,  0x32 ,  0x31 ,  0x30 ,  0x37 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x32 ,  0x36 ,  0x35 ,  0x31 ,  0x5a ,  0x18 ,  0x0f ,  0x32 ,  0x30 ,  0x39 ,  0x30 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x30 ,  0x31 ,  0x32 ,  0x31 ,  0x30 ,  0x38 ,  0x32 ,  0x36 ,  0x35 ,  0x31 ,  0x5a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x30 ,  0x0f ,  0x31 ,  0x0d ,  0x30 ,  0x0b ,  0x06 ,  0x03 ,  0x55 ,  0x04 ,  0x03 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x13 ,  0x04 ,  0x4d ,  0x6f ,  0x6e ,  0x6f ,  0x30 ,  0x81 ,  0x9d ,  0x30 ,  0x0d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x06 ,  0x09 ,  0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x01 ,  0x01 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x05 ,  0x00 ,  0x03 ,  0x81 ,  0x8b ,  0x00 ,  0x30 ,  0x81 ,  0x87 ,  0x02 ,  0x81 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x81 ,  0x00 ,  0x98 ,  0x45 ,  0x07 ,  0x52 ,  0x87 ,  0xbf ,  0x65 ,  0xb3 ,  0xb0 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x7a ,  0xa2 ,  0x87 ,  0xd3 ,  0x2f ,  0x9b ,  0x72 ,  0x9f ,  0x7c ,  0x43 ,  0x92 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x32 ,  0xff ,  0xac ,  0x87 ,  0x59 ,  0x8f ,  0x5b ,  0x7b ,  0x16 ,  0x23 ,  0xff , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x79 ,  0x54 ,  0xe3 ,  0x95 ,  0xa8 ,  0x99 ,  0xe1 ,  0x7a ,  0x63 ,  0x0c ,  0xb3 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xcd ,  0xa9 ,  0x85 ,  0x26 ,  0xcd ,  0x65 ,  0xea ,  0x0f ,  0x1e ,  0x7c ,  0xb8 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x6e ,  0xd6 ,  0xf2 ,  0x91 ,  0xb4 ,  0x51 ,  0x69 ,  0x14 ,  0x2f ,  0xf7 ,  0x8a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xed ,  0x20 ,  0xce ,  0xa0 ,  0x78 ,  0x94 ,  0x75 ,  0x7b ,  0x67 ,  0x39 ,  0x99 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf2 ,  0x56 ,  0xb4 ,  0x74 ,  0xaa ,  0xdc ,  0x46 ,  0x10 ,  0x6a ,  0xb1 ,  0xc2 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xeb ,  0xc7 ,  0x00 ,  0x66 ,  0xf0 ,  0x80 ,  0x99 ,  0x06 ,  0x46 ,  0x6b ,  0x57 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x90 ,  0x44 ,  0xd4 ,  0x6a ,  0x71 ,  0x34 ,  0x8a ,  0x5f ,  0xcc ,  0x9f ,  0xa8 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x7d ,  0x12 ,  0xa2 ,  0xe2 ,  0x04 ,  0xf6 ,  0x88 ,  0x49 ,  0xb6 ,  0x98 ,  0xa5 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xb8 ,  0xd7 ,  0xbe ,  0x5e ,  0x09 ,  0x39 ,  0x7c ,  0xab ,  0xf7 ,  0x02 ,  0x01 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x11 ,  0x30 ,  0x0d ,  0x06 ,  0x09 ,  0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x01 ,  0x01 ,  0x05 ,  0x05 ,  0x00 ,  0x03 ,  0x81 ,  0x81 ,  0x00 ,  0x4e ,  0xa9 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xa9 ,  0x28 ,  0x0a ,  0xf1 ,  0x02 ,  0x91 ,  0x1d ,  0x28 ,  0x7a ,  0x62 ,  0xf6 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x2c ,  0xf6 ,  0x84 ,  0x61 ,  0xd6 ,  0x7f ,  0x22 ,  0x44 ,  0x47 ,  0x28 ,  0xed , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x09 ,  0x99 ,  0x08 ,  0x58 ,  0xfb ,  0x50 ,  0x19 ,  0x27 ,  0xfd ,  0x08 ,  0x09 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf6 ,  0x62 ,  0xac ,  0x4f ,  0xca ,  0x35 ,  0xd9 ,  0x59 ,  0xd8 ,  0x1e ,  0xa0 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x42 ,  0x13 ,  0x00 ,  0x4d ,  0x69 ,  0x3d ,  0x5a ,  0xcb ,  0x7c ,  0xff ,  0x49 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x1e ,  0x3f ,  0x67 ,  0x7f ,  0x37 ,  0xce ,  0xeb ,  0xb8 ,  0x63 ,  0xac ,  0x71 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x8e ,  0xa3 ,  0xaa ,  0x9c ,  0xce ,  0xa0 ,  0xb7 ,  0x05 ,  0x15 ,  0xbb ,  0x9f , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf4 ,  0x86 ,  0xfc ,  0xfe ,  0x4e ,  0x1b ,  0x6e ,  0x4e ,  0x32 ,  0x2d ,  0x1b , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xa3 ,  0x72 ,  0xe4 ,  0x99 ,  0x0b ,  0x65 ,  0x94 ,  0x2d ,  0xfd ,  0x76 ,  0xc8 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe6 ,  0x48 ,  0x3d ,  0xdb ,  0x4b ,  0x7d ,  0x8e ,  0xad ,  0xef ,  0x6c ,  0x70 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x4c ,  0xb9 ,  0x7d ,  0x87 ,  0xc6 ,  0x2b ,  0xf0 ,  0x41 ,  0xee ,  0x6c ,  0xba , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x08 ,  0xcf ,  0x69 ,  0x31 ,  0x18  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  static  byte  [ ]  _pkcs12  =  new  byte  [ ]  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x30 ,  0x82 ,  0x05 ,  0x8d ,  0x02 ,  0x01 ,  0x03 ,  0x30 ,  0x82 ,  0x05 ,  0x47 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x06 ,  0x09 ,  0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x07 ,  0x01 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xa0 ,  0x82 ,  0x05 ,  0x38 ,  0x04 ,  0x82 ,  0x05 ,  0x34 ,  0x30 ,  0x82 ,  0x05 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x30 ,  0x30 ,  0x82 ,  0x02 ,  0x3f ,  0x06 ,  0x09 ,  0x2a ,  0x86 ,  0x48 ,  0x86 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf7 ,  0x0d ,  0x01 ,  0x07 ,  0x06 ,  0xa0 ,  0x82 ,  0x02 ,  0x30 ,  0x30 ,  0x82 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x02 ,  0x2c ,  0x02 ,  0x01 ,  0x00 ,  0x30 ,  0x82 ,  0x02 ,  0x25 ,  0x06 ,  0x09 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x07 ,  0x01 ,  0x30 ,  0x1c , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x06 ,  0x0a ,  0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x0c ,  0x01 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x03 ,  0x30 ,  0x0e ,  0x04 ,  0x08 ,  0x6e ,  0x0a ,  0x50 ,  0x20 ,  0xc3 ,  0x11 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x49 ,  0x07 ,  0x02 ,  0x02 ,  0x07 ,  0xd0 ,  0x80 ,  0x82 ,  0x01 ,  0xf8 ,  0x74 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x40 ,  0x07 ,  0x44 ,  0x6b ,  0x80 ,  0x46 ,  0xe1 ,  0x4e ,  0x65 ,  0x5e ,  0xf2 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf6 ,  0x38 ,  0x90 ,  0xd1 ,  0x75 ,  0x24 ,  0xd9 ,  0x72 ,  0x92 ,  0x5b ,  0x4a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xb9 ,  0x9e ,  0xbd ,  0xab ,  0xe2 ,  0xb8 ,  0x91 ,  0xc9 ,  0x48 ,  0x14 ,  0x88 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x61 ,  0x7d ,  0x06 ,  0xf9 ,  0x24 ,  0x80 ,  0xb5 ,  0x36 ,  0xaf ,  0xfe ,  0xc0 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x59 ,  0x00 ,  0x39 ,  0x3f ,  0x78 ,  0xc0 ,  0x57 ,  0xea ,  0x1e ,  0xcb ,  0x29 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xa4 ,  0x5f ,  0xba ,  0x4b ,  0xd9 ,  0xca ,  0x95 ,  0xab ,  0x55 ,  0x4a ,  0x11 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x1a ,  0xf8 ,  0xe9 ,  0xd4 ,  0xc0 ,  0x08 ,  0x55 ,  0xfb ,  0x69 ,  0x09 ,  0x0d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x5b ,  0xed ,  0x02 ,  0xcc ,  0x55 ,  0xfe ,  0x05 ,  0x2e ,  0x45 ,  0xa7 ,  0x8d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x63 ,  0x9a ,  0xda ,  0x6c ,  0xc7 ,  0xe1 ,  0xcb ,  0x5c ,  0xa7 ,  0xd9 ,  0x9b , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x4a ,  0xfb ,  0x7d ,  0x31 ,  0xe5 ,  0x89 ,  0x3e ,  0xf2 ,  0x32 ,  0xc9 ,  0x78 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xd0 ,  0x66 ,  0x1e ,  0x38 ,  0xc7 ,  0xbf ,  0x41 ,  0xf9 ,  0xe7 ,  0xbd ,  0xce , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x8b ,  0xc3 ,  0x14 ,  0x19 ,  0x4b ,  0xfa ,  0x3a ,  0xa2 ,  0x1f ,  0xb0 ,  0xd4 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xfa ,  0x33 ,  0x39 ,  0x12 ,  0xd9 ,  0x36 ,  0x7f ,  0x7e ,  0xf0 ,  0xc4 ,  0xdc , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf0 ,  0xb5 ,  0x7a ,  0x50 ,  0x2c ,  0x99 ,  0x9d ,  0x02 ,  0x40 ,  0xec ,  0x6a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x23 ,  0x83 ,  0x16 ,  0xec ,  0x8f ,  0x58 ,  0x14 ,  0xa0 ,  0xa0 ,  0x9c ,  0xa0 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe1 ,  0xd0 ,  0x6f ,  0x54 ,  0x1a ,  0x10 ,  0x47 ,  0x69 ,  0x6b ,  0x55 ,  0x7f , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x67 ,  0x7d ,  0xb8 ,  0x38 ,  0xa0 ,  0x40 ,  0x99 ,  0x13 ,  0xe8 ,  0x15 ,  0x73 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x8d ,  0x18 ,  0x86 ,  0x29 ,  0x74 ,  0xec ,  0x66 ,  0xa3 ,  0xb8 ,  0x14 ,  0x10 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x61 ,  0xef ,  0xa5 ,  0x79 ,  0x89 ,  0x01 ,  0xaa ,  0xf2 ,  0x1f ,  0x0c ,  0xdd , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x0d ,  0x8c ,  0xbb ,  0x7a ,  0x4e ,  0x0f ,  0x47 ,  0x91 ,  0x37 ,  0xa3 ,  0x8a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x43 ,  0x0f ,  0xeb ,  0xc7 ,  0x9b ,  0x8d ,  0xaf ,  0x39 ,  0xdf ,  0x23 ,  0x1c , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xa4 ,  0xf7 ,  0x66 ,  0x1c ,  0x61 ,  0x42 ,  0x24 ,  0x9a ,  0x0a ,  0x3a ,  0x31 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x9c ,  0x51 ,  0xa2 ,  0x30 ,  0xbe ,  0x85 ,  0xa6 ,  0xe8 ,  0x18 ,  0xfa ,  0x8b , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xff ,  0xdd ,  0xdc ,  0x34 ,  0x46 ,  0x4f ,  0x15 ,  0xde ,  0xdb ,  0xc4 ,  0xeb , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x62 ,  0x3b ,  0x7c ,  0x25 ,  0x1a ,  0x13 ,  0x8b ,  0xda ,  0x3b ,  0x59 ,  0x2a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xb8 ,  0x50 ,  0xe3 ,  0x9f ,  0x76 ,  0xfc ,  0xe8 ,  0x00 ,  0xfc ,  0xf7 ,  0xba , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xd2 ,  0x45 ,  0x92 ,  0x14 ,  0xb5 ,  0xe2 ,  0x93 ,  0x41 ,  0x09 ,  0xea ,  0x5b , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x5e ,  0xda ,  0x66 ,  0x92 ,  0xd1 ,  0x93 ,  0x7a ,  0xc0 ,  0xe1 ,  0x2f ,  0xed , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x29 ,  0x78 ,  0x80 ,  0xff ,  0x79 ,  0x0e ,  0xda ,  0x78 ,  0x7e ,  0x71 ,  0xa4 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x31 ,  0x2f ,  0xe9 ,  0x48 ,  0xab ,  0xc9 ,  0x40 ,  0x7d ,  0x63 ,  0x06 ,  0xd6 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xb5 ,  0x2b ,  0x49 ,  0xba ,  0x43 ,  0x56 ,  0x69 ,  0xc5 ,  0xc2 ,  0x85 ,  0x37 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xdb ,  0xe7 ,  0x39 ,  0x87 ,  0x8d ,  0x14 ,  0x15 ,  0x55 ,  0x76 ,  0x3f ,  0x70 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf6 ,  0xd7 ,  0x80 ,  0x82 ,  0x48 ,  0x02 ,  0x64 ,  0xe1 ,  0x73 ,  0x1a ,  0xd9 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x35 ,  0x1a ,  0x43 ,  0xf3 ,  0xde ,  0xd4 ,  0x00 ,  0x9d ,  0x49 ,  0x2b ,  0xc6 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x66 ,  0x19 ,  0x3e ,  0xb8 ,  0xcc ,  0x43 ,  0xcc ,  0xa8 ,  0x12 ,  0xa4 ,  0xad , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xcd ,  0xe2 ,  0xe6 ,  0xb3 ,  0xdd ,  0x7e ,  0x80 ,  0x50 ,  0xc0 ,  0xb4 ,  0x0c , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x4c ,  0xd2 ,  0x31 ,  0xf3 ,  0xf8 ,  0x49 ,  0x31 ,  0xbe ,  0xf2 ,  0x7d ,  0x60 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x38 ,  0xe0 ,  0x60 ,  0xdf ,  0x7b ,  0x58 ,  0xe0 ,  0xf9 ,  0x6e ,  0x68 ,  0x79 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x33 ,  0xb2 ,  0x2a ,  0x53 ,  0x4c ,  0x5a ,  0x9d ,  0xb3 ,  0x81 ,  0x4b ,  0x19 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x21 ,  0xe2 ,  0x3a ,  0x42 ,  0x07 ,  0x25 ,  0x5a ,  0xee ,  0x1f ,  0x5d ,  0xa2 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xca ,  0xf7 ,  0x2f ,  0x3c ,  0x9b ,  0xb0 ,  0xbc ,  0xe7 ,  0xaf ,  0x8c ,  0x2f , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x52 ,  0x43 ,  0x79 ,  0x94 ,  0xb0 ,  0xee ,  0xc4 ,  0x53 ,  0x09 ,  0xc0 ,  0xc9 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x21 ,  0x39 ,  0x64 ,  0x82 ,  0xc3 ,  0x54 ,  0xb8 ,  0x65 ,  0xf8 ,  0xdc ,  0xb3 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xdf ,  0x4d ,  0xc4 ,  0x63 ,  0x59 ,  0x14 ,  0x37 ,  0xd6 ,  0xba ,  0xa3 ,  0x98 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xda ,  0x99 ,  0x02 ,  0xdd ,  0x7a ,  0x87 ,  0x3e ,  0x34 ,  0xb5 ,  0x4b ,  0x0a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xb4 ,  0x2d ,  0xea ,  0x19 ,  0x24 ,  0xd1 ,  0xc2 ,  0x9f ,  0x30 ,  0x82 ,  0x02 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe9 ,  0x06 ,  0x09 ,  0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x07 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x01 ,  0xa0 ,  0x82 ,  0x02 ,  0xda ,  0x04 ,  0x82 ,  0x02 ,  0xd6 ,  0x30 ,  0x82 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x02 ,  0xd2 ,  0x30 ,  0x82 ,  0x02 ,  0xce ,  0x06 ,  0x0b ,  0x2a ,  0x86 ,  0x48 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x0c ,  0x0a ,  0x01 ,  0x02 ,  0xa0 ,  0x82 ,  0x02 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xa6 ,  0x30 ,  0x82 ,  0x02 ,  0xa2 ,  0x30 ,  0x1c ,  0x06 ,  0x0a ,  0x2a ,  0x86 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x0c ,  0x01 ,  0x03 ,  0x30 ,  0x0e ,  0x04 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x08 ,  0xe0 ,  0x21 ,  0x4f ,  0x90 ,  0x7d ,  0x86 ,  0x72 ,  0xc7 ,  0x02 ,  0x02 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x07 ,  0xd0 ,  0x04 ,  0x82 ,  0x02 ,  0x80 ,  0x92 ,  0xac ,  0xe8 ,  0x52 ,  0xa6 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x3e ,  0xed ,  0x3d ,  0xbc ,  0x28 ,  0x5f ,  0xb9 ,  0x45 ,  0x76 ,  0x27 ,  0x95 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf8 ,  0x6a ,  0xc5 ,  0x17 ,  0x97 ,  0x46 ,  0x58 ,  0xe9 ,  0x15 ,  0x7c ,  0x68 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x62 ,  0x67 ,  0xb5 ,  0x2f ,  0x1b ,  0x64 ,  0x27 ,  0x9d ,  0xfd ,  0x67 ,  0x66 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x42 ,  0x21 ,  0x5c ,  0xf4 ,  0x64 ,  0x37 ,  0xcc ,  0xc0 ,  0x04 ,  0x01 ,  0x91 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x6c ,  0x6b ,  0x84 ,  0x96 ,  0xae ,  0x04 ,  0xfe ,  0xcc ,  0x88 ,  0x6a ,  0x84 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xd7 ,  0x59 ,  0x28 ,  0x78 ,  0xc9 ,  0xb4 ,  0xf6 ,  0x4d ,  0x86 ,  0x8d ,  0x59 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xc6 ,  0x74 ,  0x30 ,  0xca ,  0x2f ,  0x0a ,  0xa7 ,  0x66 ,  0x99 ,  0xf4 ,  0x8f , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x44 ,  0x6d ,  0x97 ,  0x3c ,  0xd6 ,  0xdb ,  0xd6 ,  0x31 ,  0x8c ,  0xf7 ,  0x75 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xd9 ,  0x0b ,  0xf5 ,  0xd2 ,  0x27 ,  0x80 ,  0x81 ,  0x28 ,  0x0f ,  0x6b ,  0x8b , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x45 ,  0x11 ,  0x08 ,  0x1d ,  0x06 ,  0x31 ,  0x4d ,  0x98 ,  0x68 ,  0xc9 ,  0x09 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x9b ,  0x51 ,  0x84 ,  0x81 ,  0x74 ,  0x76 ,  0x57 ,  0x63 ,  0xb5 ,  0x38 ,  0xc8 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe1 ,  0x96 ,  0xe4 ,  0xcd ,  0xd4 ,  0xe8 ,  0xf8 ,  0x26 ,  0x88 ,  0x88 ,  0xaa , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xdf ,  0x1b ,  0xc6 ,  0x37 ,  0xb8 ,  0xc4 ,  0xe1 ,  0xcb ,  0xc0 ,  0x71 ,  0x3d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xd6 ,  0xd7 ,  0x8b ,  0xc6 ,  0xec ,  0x5f ,  0x42 ,  0x86 ,  0xb0 ,  0x8d ,  0x1c , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x49 ,  0xb9 ,  0xc6 ,  0x96 ,  0x11 ,  0xa5 ,  0xd6 ,  0xd2 ,  0xc0 ,  0x18 ,  0xca , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe7 ,  0xf6 ,  0x93 ,  0xb4 ,  0xf5 ,  0x7a ,  0xe4 ,  0xec ,  0xa2 ,  0x90 ,  0xf8 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xef ,  0x66 ,  0x0f ,  0xa8 ,  0x52 ,  0x0c ,  0x3f ,  0x85 ,  0x4a ,  0x76 ,  0x3a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xb8 ,  0x5a ,  0x2d ,  0x03 ,  0x5d ,  0x99 ,  0x70 ,  0xbb ,  0x02 ,  0x1c ,  0x77 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x43 ,  0x12 ,  0xd9 ,  0x1f ,  0x7c ,  0x6f ,  0x69 ,  0x15 ,  0x17 ,  0x30 ,  0x51 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x7d ,  0x53 ,  0xc2 ,  0x06 ,  0xe0 ,  0xd2 ,  0x31 ,  0x17 ,  0x2a ,  0x98 ,  0xe3 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe0 ,  0x20 ,  0xfb ,  0x01 ,  0xfd ,  0xd1 ,  0x1b ,  0x50 ,  0x00 ,  0xad ,  0x1d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xff ,  0xa1 ,  0xae ,  0xd6 ,  0xac ,  0x38 ,  0x8b ,  0x71 ,  0x28 ,  0x44 ,  0x66 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x8c ,  0xb6 ,  0x34 ,  0xc5 ,  0x86 ,  0xc9 ,  0x34 ,  0xda ,  0x6c ,  0x2a ,  0xef , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x69 ,  0x3c ,  0xb7 ,  0xbd ,  0xa5 ,  0x05 ,  0x3c ,  0x7c ,  0xfb ,  0x0c ,  0x2d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x49 ,  0x09 ,  0xdb ,  0x91 ,  0x3b ,  0x41 ,  0x2a ,  0xe4 ,  0xfa ,  0x4a ,  0xc2 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xea ,  0x9e ,  0x6f ,  0xc3 ,  0x46 ,  0x2a ,  0x77 ,  0x83 ,  0x4e ,  0x22 ,  0x01 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xfb ,  0x0c ,  0x2d ,  0x5a ,  0xcf ,  0x8d ,  0xa7 ,  0x55 ,  0x24 ,  0x7c ,  0xda , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x9e ,  0xd8 ,  0xbc ,  0xf6 ,  0x81 ,  0x63 ,  0x8a ,  0x36 ,  0xd0 ,  0x13 ,  0x74 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x30 ,  0x4d ,  0xd8 ,  0x4e ,  0xa6 ,  0x81 ,  0x71 ,  0x71 ,  0xff ,  0x9f ,  0xf3 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x8d ,  0x75 ,  0xad ,  0x6b ,  0x93 ,  0x93 ,  0x8c ,  0xf8 ,  0x7d ,  0xa6 ,  0x62 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x9d ,  0xf7 ,  0x86 ,  0x6f ,  0xcb ,  0x5b ,  0x6f ,  0xe5 ,  0xee ,  0xcd ,  0xb0 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xb2 ,  0xfd ,  0x96 ,  0x2c ,  0xde ,  0xa0 ,  0xcf ,  0x46 ,  0x8c ,  0x66 ,  0x0e , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xf9 ,  0xa3 ,  0xdb ,  0xfa ,  0x8f ,  0x1b ,  0x54 ,  0x9d ,  0x13 ,  0x13 ,  0x6b , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x97 ,  0x43 ,  0x97 ,  0x64 ,  0xec ,  0x2a ,  0xc5 ,  0xc0 ,  0x26 ,  0xab ,  0xea , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x37 ,  0xd6 ,  0xcb ,  0xb9 ,  0x83 ,  0x18 ,  0x53 ,  0x5a ,  0xcd ,  0x28 ,  0xb3 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x3b ,  0x9c ,  0x13 ,  0xaa ,  0x78 ,  0x6c ,  0xcf ,  0xe9 ,  0x75 ,  0x7c ,  0x80 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x04 ,  0x05 ,  0x52 ,  0xda ,  0x13 ,  0x41 ,  0xb0 ,  0x27 ,  0x0f ,  0x82 ,  0xa3 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x81 ,  0xd8 ,  0xf7 ,  0xdc ,  0x61 ,  0xbb ,  0x98 ,  0x32 ,  0x5a ,  0x88 ,  0xbf , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x49 ,  0xc1 ,  0x76 ,  0x83 ,  0xcd ,  0xc4 ,  0xb4 ,  0xca ,  0x8d ,  0x36 ,  0x88 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xee ,  0xdb ,  0xc5 ,  0xf4 ,  0x13 ,  0x28 ,  0x4d ,  0xae ,  0x7a ,  0x31 ,  0x3e , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x77 ,  0x19 ,  0xab ,  0x11 ,  0x15 ,  0x29 ,  0xd4 ,  0xcf ,  0xb4 ,  0x73 ,  0x36 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x92 ,  0x1e ,  0x4e ,  0x5d ,  0x35 ,  0x57 ,  0x84 ,  0x45 ,  0x9d ,  0x05 ,  0x3c , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x44 ,  0x86 ,  0x08 ,  0x0b ,  0x90 ,  0x29 ,  0xf9 ,  0xe6 ,  0x48 ,  0xaf ,  0xf4 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x62 ,  0xd2 ,  0x4d ,  0x32 ,  0x1a ,  0xe9 ,  0xbf ,  0x3a ,  0x7b ,  0x25 ,  0x4a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x03 ,  0xfb ,  0x40 ,  0x1d ,  0x71 ,  0x2c ,  0x10 ,  0x54 ,  0xdc ,  0xbf ,  0xf4 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x50 ,  0x85 ,  0x15 ,  0x11 ,  0xb1 ,  0x2d ,  0x03 ,  0x2c ,  0xe4 ,  0x8a ,  0xce , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xec ,  0x6e ,  0x46 ,  0x06 ,  0x13 ,  0x3c ,  0x97 ,  0x8d ,  0xdd ,  0xf6 ,  0x1e , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x62 ,  0xb4 ,  0x8d ,  0xfa ,  0x2c ,  0x86 ,  0x87 ,  0x64 ,  0x5e ,  0xec ,  0xc8 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x84 ,  0xd1 ,  0x3d ,  0xc5 ,  0x76 ,  0x4a ,  0x31 ,  0xd3 ,  0xdb ,  0x34 ,  0x6e , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x8a ,  0x49 ,  0xd6 ,  0x38 ,  0xbb ,  0x05 ,  0xe9 ,  0x4d ,  0xf1 ,  0xde ,  0x3e , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xa4 ,  0x47 ,  0xdd ,  0xe8 ,  0xa8 ,  0xf1 ,  0xba ,  0x55 ,  0xce ,  0xca ,  0x5b , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x57 ,  0xd7 ,  0xc8 ,  0x9f ,  0x09 ,  0xa3 ,  0x8e ,  0x58 ,  0x83 ,  0x21 ,  0x0a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x6e ,  0xd3 ,  0x70 ,  0x9c ,  0xb9 ,  0x7c ,  0x52 ,  0x98 ,  0x53 ,  0xcb ,  0xda , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x9d ,  0xaf ,  0xb7 ,  0x4b ,  0xf7 ,  0x48 ,  0x91 ,  0x7e ,  0x78 ,  0x20 ,  0x19 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe3 ,  0x41 ,  0x9d ,  0xc8 ,  0x68 ,  0x11 ,  0xfb ,  0x5f ,  0x6b ,  0xc8 ,  0x09 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x74 ,  0xcb ,  0x76 ,  0x08 ,  0xbc ,  0x28 ,  0x63 ,  0x57 ,  0x04 ,  0xb0 ,  0x80 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xd1 ,  0x53 ,  0x60 ,  0x50 ,  0x44 ,  0xba ,  0x80 ,  0x48 ,  0x5e ,  0x0e ,  0x9a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xe5 ,  0x64 ,  0x26 ,  0x7a ,  0x88 ,  0xb9 ,  0xc6 ,  0x33 ,  0x31 ,  0x15 ,  0x30 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x13 ,  0x06 ,  0x09 ,  0x2a ,  0x86 ,  0x48 ,  0x86 ,  0xf7 ,  0x0d ,  0x01 ,  0x09 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x15 ,  0x31 ,  0x06 ,  0x04 ,  0x04 ,  0x01 ,  0x00 ,  0x00 ,  0x00 ,  0x30 ,  0x3d , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x30 ,  0x21 ,  0x30 ,  0x09 ,  0x06 ,  0x05 ,  0x2b ,  0x0e ,  0x03 ,  0x02 ,  0x1a , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x05 ,  0x00 ,  0x04 ,  0x14 ,  0x32 ,  0x55 ,  0x07 ,  0xa2 ,  0x67 ,  0xf3 ,  0x76 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x4d ,  0x0b ,  0x6f ,  0xa4 ,  0xa0 ,  0x7b ,  0xce ,  0x2f ,  0xc5 ,  0xff ,  0xbe , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x3e ,  0x38 ,  0x04 ,  0x14 ,  0x52 ,  0xf8 ,  0xb3 ,  0xeb ,  0xc3 ,  0xda ,  0x79 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0xfa ,  0x75 ,  0x89 ,  0x67 ,  0x33 ,  0x01 ,  0xd0 ,  0xb0 ,  0x13 ,  0xfa ,  0x11 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											0x94 ,  0xac ,  0x02 ,  0x02 ,  0x07 ,  0xd0  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  SignedXml  SignHMAC  ( string  uri ,  KeyedHashAlgorithm  mac ,  bool  ok ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  input  =  "<foo/>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( input ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sig  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Reference  r  =  new  Reference  ( "" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											r . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											r . DigestMethod  =  uri ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sig . AddReference  ( r ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sig . ComputeSignature  ( mac ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . DocumentElement . AppendChild  ( doc . ImportNode  ( sig . GetXml  ( ) ,  true ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// doc.Save (System.Console.Out); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sig . LoadXml  ( doc . DocumentElement  [ "Signature" ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( ok ,  sig . CheckSignature  ( mac ) ,  "CheckSignature" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  sig ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										static  byte  [ ]  hmackey  =  new  byte  [ 0 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  const  string  more256  =  "http://www.w3.org/2001/04/xmldsig-more#hmac-sha256" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  const  string  more384  =  "http://www.w3.org/2001/04/xmldsig-more#hmac-sha384" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  const  string  more512  =  "http://www.w3.org/2001/04/xmldsig-more#hmac-sha512" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										private  const  string  moreripe  =  "http://www.w3.org/2001/04/xmldsig-more#hmac-ripemd160" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_SHA256  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( EncryptedXml . XmlEncSHA256Url ,  new  HMACSHA256  ( hmackey ) ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( more256 ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_SHA256_Bad  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( more256 ,  new  HMACSHA256  ( hmackey ) ,  false ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( more256 ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  VerifyHMAC_SHA256  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  "<?xml version=\"1.0\" encoding=\"Windows-1252\"?><foo><Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2001/04/xmldsig-more#hmac-sha256\" /><Reference URI=\"\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" /></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2001/04/xmlenc#sha256\" /><DigestValue>sKG2hDPEHiPrzpd3QA8BZ0eMzMbSEPPMh9QqXgkP7Cs=</DigestValue></Reference></SignedInfo><SignatureValue>Faad3KInJdIpaGcBn5e04Zv080u45fSjAKqrgevdWQw=</SignatureValue></Signature></foo>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sign . LoadXml  ( doc . DocumentElement  [ "Signature" ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// verify MS-generated signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sign . CheckSignature  ( new  HMACSHA256  ( hmackey ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_SHA512  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( EncryptedXml . XmlEncSHA512Url ,  new  HMACSHA512  ( hmackey ) ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( more512 ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_SHA512_Bad  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( more512 ,  new  HMACSHA512  ( hmackey ) ,  false ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( more512 ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  VerifyHMAC_SHA512  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  "<?xml version=\"1.0\" encoding=\"Windows-1252\"?><foo><Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2001/04/xmldsig-more#hmac-sha512\" /><Reference URI=\"\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" /></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2001/04/xmlenc#sha512\" /><DigestValue>2dvMkpTUE8Z76ResJG9pwPpVJNYo7t6s2L02V81xUVJ0oF8yJ7v8CTojjuL76s0iVdBxAOhP80Ambd1YaSkwSw==</DigestValue></Reference></SignedInfo><SignatureValue>wFenihRlm1x5/n0cifdX/TDOYqlbg2oVIbD/gyrAc0Q2hiIUTtwfBIMY5rQhKcErSz6YNoIl8RBQBmww/0rv5g==</SignatureValue></Signature></foo>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sign . LoadXml  ( doc . DocumentElement  [ "Signature" ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// verify MS-generated signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sign . CheckSignature  ( new  HMACSHA512  ( hmackey ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_SHA384  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// works as long as the string can be used by CryptoConfig to create  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// an instance of the required hash algorithm 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( "SHA384" ,  new  HMACSHA384  ( hmackey ) ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( more384 ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_SHA384_Bad  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// we can't verity the signature if the URI is used 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( more384 ,  new  HMACSHA384  ( hmackey ) ,  false ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( more384 ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  VerifyHMAC_SHA384  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  "<?xml version=\"1.0\" encoding=\"Windows-1252\"?><foo><Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2001/04/xmldsig-more#hmac-sha384\" /><Reference URI=\"\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" /></Transforms><DigestMethod Algorithm=\"SHA384\" /><DigestValue>kH9C0LeZocNVXhjfzpz00M5fc3WJf0QU8gxK4I7pAN7HN602yHo8yYDSlG14b5YS</DigestValue></Reference></SignedInfo><SignatureValue>LgydOfhv8nqpFLFPC+xg3ZnjC8D+V3mpzxv6GOdH1HDdw1r+LH/BFM2U7dntxgf0</SignatureValue></Signature></foo>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sign . LoadXml  ( doc . DocumentElement  [ "Signature" ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// verify MS-generated signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sign . CheckSignature  ( new  HMACSHA384  ( hmackey ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_RIPEMD160  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// works as long as the string can be used by CryptoConfig to create  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// an instance of the required hash algorithm 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( "RIPEMD160" ,  new  HMACRIPEMD160  ( hmackey ) ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( moreripe ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  SignHMAC_RIPEMD160_Bad  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// we can't verity the signature if the URI is used 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  SignHMAC  ( moreripe ,  new  HMACRIPEMD160  ( hmackey ) ,  false ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . AreEqual  ( moreripe ,  sign . SignatureMethod ,  "SignatureMethod" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  VerifyHMAC_RIPEMD160  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  "<?xml version=\"1.0\" encoding=\"Windows-1252\"?><foo><Signature xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><SignedInfo><CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><SignatureMethod Algorithm=\"http://www.w3.org/2001/04/xmldsig-more#hmac-ripemd160\" /><Reference URI=\"\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" /></Transforms><DigestMethod Algorithm=\"RIPEMD160\" /><DigestValue>+uyqtoSDPvgrsXCl1KCimhFpOVw=</DigestValue></Reference></SignedInfo><SignatureValue>8E2m/A5lyU6mBug7uskBqpDHuvs=</SignatureValue></Signature></foo>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sign . LoadXml  ( doc . DocumentElement  [ "Signature" ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// verify MS-generated signature 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sign . CheckSignature  ( new  HMACRIPEMD160  ( hmackey ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										static  SignedXml  GetSignedXml  ( string  xml ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											XmlDocument  doc  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											doc . LoadXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  new  SignedXml  ( doc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sign . LoadXml  ( doc . DocumentElement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  sign ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  CheckSignature_WhenHmacOutputLengthIsNotMultipleOf8_ThrowsCryptographicException  ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  @"<?xml version=""1.0"" encoding=""UTF-8" "?>
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< Signature  xmlns = "" http : //www.w3.org/2000/09/xmldsig#"">  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < SignedInfo > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < CanonicalizationMethod  Algorithm = "" http : //www.w3.org/TR/2001/REC-xml-c14n-20010315"" /> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < SignatureMethod  Algorithm = "" http : //www.w3.org/2000/09/xmldsig#hmac-sha1"" > 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      < HMACOutputLength > 81 < / HMACOutputLength > 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    < / SignatureMethod > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < Reference  URI = "" # object "" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < DigestMethod  Algorithm = "" http : //www.w3.org/2000/09/xmldsig#sha1"" /> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < DigestValue > nz4GS0NbH2SrWlD / 4f X313CoTzc = < / DigestValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < / Reference > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / SignedInfo > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < SignatureValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    gA = = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / SignatureValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < Object  Id = "" object "" > some  other  text < / Object > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / Signature >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								";
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											var  sut  =  GetSignedXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sut . SignatureFormatValidator  =  null ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											var  ex  =  Assert . Throws < CryptographicException >  ( ( )  = >  sut . CheckSignature  ( new  HMACSHA1  ( Encoding . ASCII . GetBytes  ( "secret" ) ) ) ,  "Exception" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( ex . Message ,  Is . StringContaining  ( "multiple of 8" ) . IgnoreCase ,  "Message" ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										public  void  CheckSignature_WhenDefaultSignatureFormatValidatorIsUsedAndSignatureUsesTruncatedHmac_ReturnsFalse  ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											// The HMAC output length is 128, which is a half of HMACSHA256 that we're going to use. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  @"<Signature xmlns=""http://www.w3.org/2000/09/xmldsig#""><SignedInfo><CanonicalizationMethod Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-20010315"" /><SignatureMethod Algorithm=""http://www.w3.org/2001/04/xmldsig-more#hmac-sha256""><HMACOutputLength>128</HMACOutputLength></SignatureMethod><Reference URI=""#object""><DigestMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#sha1"" /><DigestValue>nz4GS0NbH2SrWlD/4fX313CoTzc=</DigestValue></Reference></SignedInfo><SignatureValue>aegpvkAwOL8gN/CjSnW6qw==</SignatureValue><Object Id=""object"">some other text</Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  sut  =  GetSignedXml  ( xml ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											// Although the XML Signature standard allows using truncated HMACs (with some limitations), 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// .NET Framework, by default, doesn't allow using them, since it may result in security issues. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( sut . CheckSignature  ( new  HMACSHA256  ( Encoding . ASCII . GetBytes  ( "secret" ) ) ) ,  Is . False ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										public  void  CheckSignature_WhenDefaultSignatureFormatValidatorIsNotUsedAndSignatureUsesTruncatedHmac_ReturnsTrue  ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											// The HMAC output length is 128, which is a half of HMACSHA256 that we're going to use. 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											string  xml  =  @"<Signature xmlns=""http://www.w3.org/2000/09/xmldsig#""><SignedInfo><CanonicalizationMethod Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-20010315"" /><SignatureMethod Algorithm=""http://www.w3.org/2001/04/xmldsig-more#hmac-sha256""><HMACOutputLength>128</HMACOutputLength></SignatureMethod><Reference URI=""#object""><DigestMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#sha1"" /><DigestValue>nz4GS0NbH2SrWlD/4fX313CoTzc=</DigestValue></Reference></SignedInfo><SignatureValue>aegpvkAwOL8gN/CjSnW6qw==</SignatureValue><Object Id=""object"">some other text</Object></Signature>" ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											var  sut  =  GetSignedXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// By default, .NET Framework doesn't allow using truncated HMACs, since it may lead to security issues. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// That being said, the XML Signature standard allows using truncated HMACs, but with some limitations. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// It's possible to use truncated HMACs by using a custom signature format validator, or not using it at all. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sut . SignatureFormatValidator  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( sut . CheckSignature  ( new  HMACSHA256  ( Encoding . ASCII . GetBytes  ( "secret" ) ) ) ,  Is . True ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  VerifyHMAC_FullLength  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  @"<Signature xmlns=""http://www.w3.org/2000/09/xmldsig#""><SignedInfo><CanonicalizationMethod Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-20010315"" /><SignatureMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#hmac-sha1"" /><Reference URI=""#object""><DigestMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#sha1"" /><DigestValue>7/XTsHaBSOnJ/jXD5v0zL6VKYsk=</DigestValue></Reference></SignedInfo><SignatureValue>a0goL9esBUKPqtFYgpp2KST4huk=</SignatureValue><Object Id=""object"">some text</Object></Signature>" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											SignedXml  sign  =  GetSignedXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . IsTrue  ( sign . CheckSignature  ( new  HMACSHA1  ( Encoding . ASCII . GetBytes  ( "secret" ) ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										public  void  CheckSignature_WhenSignatureLengthIsGreaterThanHmacOutputLength_ThrowsCryptographicException  ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  @"<?xml version=""1.0"" encoding=""UTF-8" "?>
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< Signature  xmlns = "" http : //www.w3.org/2000/09/xmldsig#"">  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < SignedInfo > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < CanonicalizationMethod  Algorithm = "" http : //www.w3.org/TR/2001/REC-xml-c14n-20010315"" /> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < SignatureMethod  Algorithm = "" http : //www.w3.org/2000/09/xmldsig#hmac-sha1"" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < HMACOutputLength > 80 < / HMACOutputLength > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < / SignatureMethod > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < Reference  URI = "" # object "" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < DigestMethod  Algorithm = "" http : //www.w3.org/2000/09/xmldsig#sha1"" /> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < DigestValue > nz4GS0NbH2SrWlD / 4f X313CoTzc = < / DigestValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < / Reference > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / SignedInfo > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < SignatureValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / SignatureValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < Object  Id = "" object "" > some  other  text < / Object > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / Signature >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								";
  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											var  sut  =  GetSignedXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sut . SignatureFormatValidator  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  ex  =  Assert . Throws < CryptographicException >  ( ( )  = >  sut . CheckSignature  ( new  HMACSHA1  ( Encoding . ASCII . GetBytes  ( "no clue" ) ) ) ,  "Exception" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( ex . Message ,  Is . StringContaining  ( "length of the signature" ) . IgnoreCase ,  "Message" ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										public  void  CheckSignature_WhenHmacOutputLengthIsInvalid_ThrowsFormatException  ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											string  xml  =  @"<?xml version=""1.0"" encoding=""UTF-8" "?>
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< Signature  xmlns = "" http : //www.w3.org/2000/09/xmldsig#"">  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < SignedInfo > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < CanonicalizationMethod  Algorithm = "" http : //www.w3.org/TR/2001/REC-xml-c14n-20010315"" /> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < SignatureMethod  Algorithm = "" http : //www.w3.org/2000/09/xmldsig#hmac-sha1"" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < HMACOutputLength > I  wish  this  was  not  a  string  property < / HMACOutputLength > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < / SignatureMethod > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < Reference  URI = "" # object "" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < DigestMethod  Algorithm = "" http : //www.w3.org/2000/09/xmldsig#sha1"" /> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < DigestValue > nz4GS0NbH2SrWlD / 4f X313CoTzc = < / DigestValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < / Reference > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / SignedInfo > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < SignatureValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / SignatureValue > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < Object  Id = "" object "" > some  other  text < / Object > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / Signature >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								";
  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											var  sut  =  GetSignedXml  ( xml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sut . SignatureFormatValidator  =  null ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . Throws < FormatException >  ( ( )  = >  sut . CheckSignature  ( new  HMACSHA1  ( Encoding . ASCII . GetBytes  ( "no clue" ) ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-07 13:16:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignature_WhenSigningKeyIsNotSpecified_ThrowsCryptographicException  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  unsignedXml  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsignedXml . LoadXml  ( "<test />" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  reference  =  new  Reference  {  Uri  =  ""  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signedXml  =  new  SignedXml  ( unsignedXml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  ex  =  Assert . Throws < CryptographicException >  ( ( )  = >  signedXml . ComputeSignature ( ) ,  "Exception" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( ex . Message ,  Is . EqualTo  ( SR . Cryptography_Xml_LoadKeyFailed ) ,  "Message" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										public  void  ComputeSignature_WhenSignatureMethodIsNotSpecifiedAndRsaSigningKeyIsUsed_UsesRsaSha256Algorithm  ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-07 13:16:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  unsignedXml  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsignedXml . LoadXml  ( "<test />" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  reference  =  new  Reference  {  Uri  =  ""  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signedXml  =  new  SignedXml  ( unsignedXml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  RSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  namespaceManager  =  new  XmlNamespaceManager  ( signature . OwnerDocument . NameTable ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											namespaceManager . AddNamespace  ( "ds" ,  SignedXml . XmlDsigNamespaceUrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signatureMethodElement  =  signature . SelectSingleNode  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												string . Format  ( "/{0}:SignedInfo/{0}:SignatureMethod" ,  XmlDsigNamespacePrefix ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												namespaceManager ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-24 09:31:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											Assert . That  ( signatureMethodElement . Attributes [ "Algorithm" ] . Value ,  Is . EqualTo  ( SignedXml . XmlDsigRSASHA256Url ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-07 13:16:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignature_WhenSignatureMethodIsNotSpecifiedAndDsaSigningKeyIsUsed_UsesDsaSha1Algorithm  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  unsignedXml  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsignedXml . LoadXml  ( "<test />" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  reference  =  new  Reference  {  Uri  =  ""  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signedXml  =  new  SignedXml  ( unsignedXml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  DSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  namespaceManager  =  new  XmlNamespaceManager  ( signature . OwnerDocument . NameTable ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											namespaceManager . AddNamespace  ( "ds" ,  SignedXml . XmlDsigNamespaceUrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signatureMethodElement  =  signature . SelectSingleNode  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												string . Format  ( "/{0}:SignedInfo/{0}:SignatureMethod" ,  XmlDsigNamespacePrefix ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												namespaceManager ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( signatureMethodElement . Attributes [ "Algorithm" ] . Value ,  Is . EqualTo  ( SignedXml . XmlDsigDSAUrl ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignature_WhenSignatureMethodIsNotSpecifiedAndNotSupportedSigningKeyIsUsed_ThrowsCryptographicException  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  unsignedXml  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsignedXml . LoadXml  ( "<test />" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  reference  =  new  Reference  {  Uri  =  ""  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signedXml  =  new  SignedXml  ( unsignedXml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  new  CustomAsymmetricAlgorithm  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  ex  =  Assert . Throws < CryptographicException >  ( ( )  = >  signedXml . ComputeSignature  ( ) ,  "Exception" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( ex . Message ,  Is . EqualTo  ( SR . Cryptography_Xml_CreatedKeyFailed ) ,  "Message" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignature_WhenNotSupportedSignatureMethodIsSpecified_ThrowsCryptographicException  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  unsignedXml  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsignedXml . LoadXml  ( "<test />" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  reference  =  new  Reference  {  Uri  =  ""  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signedXml  =  new  SignedXml  ( unsignedXml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  RSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SignedInfo . SignatureMethod  =  "not supported signature method" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  ex  =  Assert . Throws < CryptographicException >  ( ( )  = >  signedXml . ComputeSignature ( ) ,  "Exception" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( ex . Message ,  Is . EqualTo  ( SR . Cryptography_Xml_SignatureDescriptionNotCreated ) ,  "Message" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignature_WhenNotSupportedSignatureHashAlgorithmIsSpecified_ThrowsCryptographicException  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											const  string  algorithmName  =  "not supported signature hash algorithm" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											CryptoConfig . AddAlgorithm  ( typeof  ( BadHashAlgorithmSignatureDescription ) ,  algorithmName ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  unsignedXml  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsignedXml . LoadXml  ( "<test />" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  reference  =  new  Reference  {  Uri  =  ""  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signedXml  =  new  SignedXml  ( unsignedXml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  RSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SignedInfo . SignatureMethod  =  algorithmName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  ex  =  Assert . Throws < CryptographicException >  ( ( )  = >  signedXml . ComputeSignature  ( ) ,  "Exception" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( ex . Message ,  Is . EqualTo  ( SR . Cryptography_Xml_CreateHashAlgorithmFailed ) ,  "Message" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										[Test]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										public  void  ComputeSignature_WhenCustomSignatureMethodIsSpecified_UsesCustomAlgorithm  ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											const  string  algorithmName  =  "http://www.w3.org/2001/04/xmldsig-more#rsa-sha512" ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											CryptoConfig . AddAlgorithm  ( typeof  ( RsaPkcs1Sha512SignatureDescription ) ,  algorithmName ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  unsignedXml  =  new  XmlDocument  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsignedXml . LoadXml  ( "<test />" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  reference  =  new  Reference  {  Uri  =  ""  } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reference . AddTransform  ( new  XmlDsigEnvelopedSignatureTransform  ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signedXml  =  new  SignedXml  ( unsignedXml ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SigningKey  =  RSA . Create  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . SignedInfo . SignatureMethod  =  algorithmName ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . AddReference  ( reference ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											signedXml . ComputeSignature  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signature  =  signedXml . GetXml  ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  namespaceManager  =  new  XmlNamespaceManager  ( signature . OwnerDocument . NameTable ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											namespaceManager . AddNamespace  ( "ds" ,  SignedXml . XmlDsigNamespaceUrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											var  signatureMethodElement  =  signature . SelectSingleNode  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												string . Format  ( "/{0}:SignedInfo/{0}:SignatureMethod" ,  XmlDsigNamespacePrefix ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												namespaceManager ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											Assert . That  ( signatureMethodElement . Attributes [ "Algorithm" ] . Value ,  Is . EqualTo  ( algorithmName ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2014-08-13 10:39:27 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-28 19:36:51 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#endif