<PackageReference Include="BouncyCastle.Cryptography" Version="2.6.0" />

MessageImprint

public class MessageImprint : Asn1Encodable
using Org.BouncyCastle.Asn1.X509; using System; namespace Org.BouncyCastle.Asn1.Tsp { public class MessageImprint : Asn1Encodable { private readonly AlgorithmIdentifier m_hashAlgorithm; private readonly Asn1OctetString m_hashedMessage; public AlgorithmIdentifier HashAlgorithm => m_hashAlgorithm; public Asn1OctetString HashedMessage => m_hashedMessage; public static MessageImprint GetInstance(object obj) { if (obj == null) return null; MessageImprint messageImprint = obj as MessageImprint; if (messageImprint != null) return messageImprint; return new MessageImprint(Asn1Sequence.GetInstance(obj)); } public static MessageImprint GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new MessageImprint(Asn1Sequence.GetInstance(taggedObject, declaredExplicit)); } public static MessageImprint GetTagged(Asn1TaggedObject taggedObject, bool declaredExplicit) { return new MessageImprint(Asn1Sequence.GetTagged(taggedObject, declaredExplicit)); } private MessageImprint(Asn1Sequence seq) { int count = seq.Count; if (count != 2) throw new ArgumentException("Bad sequence size: " + count.ToString(), "seq"); m_hashAlgorithm = AlgorithmIdentifier.GetInstance(seq[0]); m_hashedMessage = Asn1OctetString.GetInstance(seq[1]); } public MessageImprint(AlgorithmIdentifier hashAlgorithm, Asn1OctetString hashedMessage) { if (hashAlgorithm == null) throw new ArgumentNullException("hashAlgorithm"); m_hashAlgorithm = hashAlgorithm; if (hashedMessage == null) throw new ArgumentNullException("hashedMessage"); m_hashedMessage = hashedMessage; } public MessageImprint(AlgorithmIdentifier hashAlgorithm, byte[] hashedMessage) { if (hashAlgorithm == null) throw new ArgumentNullException("hashAlgorithm"); m_hashAlgorithm = hashAlgorithm; m_hashedMessage = DerOctetString.FromContents(hashedMessage); } public byte[] GetHashedMessage() { return m_hashedMessage.GetOctets(); } public override Asn1Object ToAsn1Object() { return new DerSequence(m_hashAlgorithm, m_hashedMessage); } } }