「DFÜ 協定」の仕様では、SHA256 によって SEPA コンテナの支払いファイルのハッシュ値を計算することが記述されています。
ハッシュ値は、開始および終了の「document」タグを含む、含まれているドキュメント全体を使用して作成されます。
このドキュメントは、Canonical XML バージョン 1.0 に従って正規化されています。( http://www.w3.org/TR/2001/REC-xml-c14n-20010315 )。
含まれるドキュメントの場合、正規化もメイン ドキュメントに従って実行する必要があります。
SHA-256 はハッシュ アルゴリズムとして使用されます。
ハッシュ値はタグに 16 進数形式で入力され、大文字は 16 進数の A から F に使用されます。SRZ プロシージャ内で XML コンテナーを使用する場合、ハッシュ値を指定することが必須です (略語 SRZ はドイツ語の用語を表します)。 「Servicerechenzentrum」は「データ処理サービス センター」を意味します)。
それを行うためにさまざまな方法を試しましたが、正しい値を取得できません。
[Test]
public void GetHashTest()
{
// load document
XmlDocument sepaContainer = new XmlDocument();
sepaContainer.PreserveWhitespace = true;
sepaContainer.Load("PathToFile");
// do canonical
XmlDsigC14NTransform transformer = new XmlDsigC14NTransform();
transformer.LoadInput(document);
string compare = string.Empty;
foreach (byte b in transformer.GetDigestedOutput(new SHA256Managed()))
{
compare += b.ToString("X2");
}
Assert.That(compare, Is.EqualTo("1FA8EE4F1E9551C82E1C7A82A88140325453A52BD08FF9FA5D13CA40F04AB305"));
}
また、ファイルを文字列に読み取って計算することもできません。
private string GetSHA256(string text)
{
UTF8Encoding UE = new UTF8Encoding();
byte[] message = UE.GetBytes(text);
SHA256Managed hashString = new SHA256Managed();
string hex = string.Empty;
byte[] hashValue = hashString.ComputeHash(message);
foreach (byte x in hashValue)
{
hex += string.Format("{0:X2}", x);
}
return hex;
}
現在、私はここから SEPA XML コンテナーを使用しています: http://entwickler-forum.de/showthread.php/64499-Auslesen-einer-XML-Datei
<?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>2010-10-26T14:48:17Z</CreDtTm>
<MsgPain008>
<HashValue>38B862BD35B95D8CB20448153B5F6F73B3657EB1BC81CF11D3491D16EEA94009</HashValue>
<HashAlgorithm>SHA256</HashAlgorithm>
<Document xmlns="urn:swift:xsd:$pain.008.002.01">
<pain.008.001.01>
<GrpHdr>
<MsgId>D004201010261648081</MsgId>
<CreDtTm>2010-10-26T14:48:08Z</CreDtTm>
<NbOfTxs>1</NbOfTxs>
<CtrlSum>0.20</CtrlSum>
<Grpg>MIXD</Grpg>
<InitgPty>
<Nm>Testauftraggeber SEPA-LS</Nm>
</InitgPty>
</GrpHdr>
<PmtInf>
<PmtInfId>D00420101024444444081</PmtInfId>
<PmtMtd>DD</PmtMtd>
<PmtTpInf>
<SvcLvl>
<Cd>SEPA</Cd>
</SvcLvl>
<LclInstrm>
<Cd>CORE</Cd>
</LclInstrm>
<SeqTp>OOFF</SeqTp>
</PmtTpInf>
<ReqdColltnDt>2010-11-02</ReqdColltnDt>
<Cdtr>
<Nm>Testauftraggeber SEPA-LS</Nm>
</Cdtr>
<CdtrAcct>
<Id>
<IBAN>DE352505018444402014</IBAN>
</Id>
</CdtrAcct>
<CdtrAgt>
<FinInstnId>
<BIC>SPKHDE2HXXX</BIC>
</FinInstnId>
</CdtrAgt>
<ChrgBr>SLEV</ChrgBr>
<DrctDbtTxInf>
<PmtId>
<EndToEndId>Lastschriftreferenz 002</EndToEndId>
</PmtId>
<InstdAmt Ccy="EUR">0.20</InstdAmt>
<DrctDbtTx>
<MndtRltdInf>
<MndtId>Mandat002</MndtId>
<DtOfSgntr>2010-10-26</DtOfSgntr>
<AmdmntInd>false</AmdmntInd>
</MndtRltdInf>
<CdtrSchmeId>
<Id>
<PrvtId>
<OthrId>
<Id>DE98ZZZ09999999999</Id>
<IdTp>SEPA</IdTp>
</OthrId>
</PrvtId>
</Id>
</CdtrSchmeId>
</DrctDbtTx>
<DbtrAgt>
<FinInstnId>
<BIC>SPKHDE2HXXX</BIC>
</FinInstnId>
</DbtrAgt>
<Dbtr>
<Nm>Test Zahlungspflichtiger</Nm>
</Dbtr>
<DbtrAcct>
<Id>
<IBAN>DE132505018005555552</IBAN>
</Id>
</DbtrAcct>
<UltmtDbtr>
<Nm>Test Miete</Nm>
</UltmtDbtr>
<RmtInf>
<Ustrd>Test SEPA-LS Einzug durch 10002014 Zahlungspflichtiger 10002022</Ustrd>
</RmtInf>
</DrctDbtTxInf>
</PmtInf>
</pain.008.001.01>
</Document>
</MsgPain008>
</conxml>
「ドキュメント」ノードを手と xpath で抽出しましたが、それでも別の値が得られ、チェック ハッシュが計算されます。
うまくいけば、あなたの誰かがアイデアを持っていますか?
編集: 26.08.2013 - xml ファイルの特定のハッシュ値を変更 (修正)