我正在努力解决像 Markus Dreyer 一样的问题: C#Calculate SHA256 value for SEPA (XML) paymentfile
根据 DFÜ 协议,我必须计算一个 sha256 哈希值:
- 哈希值是使用整个包含的文档创建的,包括开始和结束标签。
- 该文档根据 Canonical XML 1.0 版进行了规范化。(http://www.w3.org/TR/2001/REC-xml-c14n-20010315)。
- 在包含文档的情况下,也必须根据主文档执行规范化。
- SHA-256 用作哈希算法。
这是一个示例有效的 xml 文件(从金融工具导出):
<?xml version="1.0" encoding="UTF-8"?>
<conxml xmlns="urn:conxml:xsd:container.nnn.002" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:conxml:xsd:container.nnn.002 container.nnn.002.xsd">
<CreDtTm>2013-08-27T07:20:25Z</CreDtTm>
<MsgPain001>
<HashValue>33E579FE7A9AF6C32C100E8578EBD63E54A2DF47C6849F7A4BC8BEA9E2794197</HashValue>
<HashAlgorithm>SHA256</HashAlgorithm>
<Document xmlns="urn:swift:xsd:$pain.001.002.02">
<pain.001.001.02>
<GrpHdr>
<MsgId>D005201308270920191</MsgId>
<CreDtTm>2013-08-27T07:20:19Z</CreDtTm>
<BtchBookg>true</BtchBookg>
<NbOfTxs>1</NbOfTxs>
<CtrlSum>0.50</CtrlSum>
<Grpg>MIXD</Grpg>
<InitgPty>
<Nm>Test</Nm>
</InitgPty>
</GrpHdr>
<PmtInf>
<PmtInfId>D005201308270920191</PmtInfId>
<PmtMtd>TRF</PmtMtd>
<PmtTpInf>
<SvcLvl>
<Cd>SEPA</Cd>
</SvcLvl>
</PmtTpInf>
<ReqdExctnDt>2013-08-27</ReqdExctnDt>
<Dbtr>
<Nm>Test</Nm>
</Dbtr>
<DbtrAcct>
<Id>
<IBAN>DE76200700000888888888</IBAN>
</Id>
</DbtrAcct>
<DbtrAgt>
<FinInstnId>
<BIC>DEUTDEHHXXX</BIC>
</FinInstnId>
</DbtrAgt>
<ChrgBr>SLEV</ChrgBr>
<CdtTrfTxInf>
<PmtId>
<EndToEndId>NOTPROVIDED</EndToEndId>
</PmtId>
<Amt>
<InstdAmt Ccy="EUR">0.50</InstdAmt>
</Amt>
<CdtrAgt>
<FinInstnId>
<BIC>DEUTDEHHXXX</BIC>
</FinInstnId>
</CdtrAgt>
<Cdtr>
<Nm>Erwin Mustermann</Nm>
</Cdtr>
<CdtrAcct>
<Id>
<IBAN>DE09200700000123456789</IBAN>
</Id>
</CdtrAcct>
<RmtInf>
<Ustrd>Sepa Test Gutschrift</Ustrd>
</RmtInf>
</CdtTrfTxInf>
</PmtInf>
</pain.001.001.02>
</Document>
</MsgPain001>
</conxml>
根据 Markus Dreyer 的解决方案,这是我的代码:
System.Text.UTF8Encoding enc = new UTF8Encoding(false);
XmlDocument doc = new XmlDocument();
doc.PreserveWhitespace = true;
doc.Load(@"path to file");
XmlNodeList list = doc.GetElementsByTagName("Document");
String s = list.Item(0).OuterXml;
MemoryStream msIn = new MemoryStream(enc.GetBytes(s));
XmlDsigC14NTransform t = new XmlDsigC14NTransform(true);
t.LoadInput(msIn);
MemoryStream ms = new MemoryStream();
ms = (MemoryStream)t.GetOutput(typeof(MemoryStream));
byte[] digest = t.GetDigestedOutput(new SHA256Managed());
String result = BitConverter.ToString(digest).Replace("-", String.Empty);
在我的计算中,我得到了值:55B2597B0688AB1A19760B542AA70AEF4F980D7BC9D6EBCF2B741F6299C661D3 但预期是文件中的值:33E579FE7A9AF6C32C100E8578EBD63E54A2DF47C6849F7A47BC8BEA9E
你们有任何想法,我错过了什么?