Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) XML Inclusive CanonicalizationDemonstrates how to convert XML to the Inclusive XML Canonicalization form as specified in http://www.w3.org/TR/xml-c14n/
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. -- The XML digital signature verification class provides utility methods for -- XML canonicalization. This example demonstrates how to do inclusive XML canonicalization. DECLARE @http int -- Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @sbXml int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbXml OUT DECLARE @canon int -- Use "Chilkat_9_5_0.XmlDSig" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.XmlDSig', @canon OUT -- Use inclusive XML canonicalization. DECLARE @canonVersion nvarchar(4000) SELECT @canonVersion = 'C14N' DECLARE @withComments int SELECT @withComments = 0 DECLARE @url nvarchar(4000) SELECT @url = 'https://www.chilkatsoft.com/exampleData/c14n/test7.xml' DECLARE @success int EXEC sp_OAMethod @http, 'QuickGetSb', @success OUT, @url, @sbXml -- This is the input XML: -- The XML comment is referring to when exclusive XML canonicalization is applied. With inclusive canonicalization, the namespace nodes -- are kept, as we'll see below.. -- <doc> -- <!-- A namespace node N is ignored if the nearest ancestor element of the node's parent element that is in the node-set has a namespace node in the node-set with the same local name and value as N. --> -- <animal xmlns:aa="https://www.animal.com/"> -- <reptile xmlns:bb="https://www.reptile.com/"> -- <lizard xmlns="" type="african fat tailed" abc="xyz" xmlns:aa="https://www.animal.com/" /> -- <snake type="poisonous rattler" xmlns:bb="https://www.reptile.com/" > -- </snake> -- </reptile> -- </animal> -- </doc> DECLARE @xmlInclCanon nvarchar(4000) EXEC sp_OAMethod @sbXml, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @canon, 'CanonicalizeXml', @xmlInclCanon OUT, @sTmp0, @canonVersion, @withComments PRINT @xmlInclCanon -- The C14N (inclusive) canonicalization is: -- <doc> -- -- <animal xmlns:aa="https://www.animal.com/"> -- <reptile xmlns:bb="https://www.reptile.com/"> -- <lizard abc="xyz" type="african fat tailed"></lizard> -- <snake type="poisonous rattler"> -- </snake> -- </reptile> -- </animal> -- </doc> -- To see the difference, let's do exclusive canonicalization.. SELECT @canonVersion = 'EXCL_C14N' DECLARE @xmlExclCanon nvarchar(4000) EXEC sp_OAMethod @sbXml, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @canon, 'CanonicalizeXml', @xmlExclCanon OUT, @sTmp0, @canonVersion, @withComments PRINT @xmlExclCanon -- // The C14N (exclusive) canonicalization is: -- -- <doc> -- -- <animal> -- <reptile> -- <lizard abc="xyz" type="african fat tailed"></lizard> -- <snake type="poisonous rattler"> -- </snake> -- </reptile> -- </animal> -- </doc> EXEC @hr = sp_OADestroy @http EXEC @hr = sp_OADestroy @sbXml EXEC @hr = sp_OADestroy @canon END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.