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) Another SOAP with MTOM XOP Attachment ExampleSee more HTTP ExamplesDemonstrates another multipart/related MTOM SOAP request that adds additional headers in each MIME sub-part, and also specifies Content-Transfer-Encoding in the sub-parts. Note: This example requires Chilkat v9.5.0.92 or greater.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- Note: This example requires Chilkat v9.5.0.92 or greater. -- This example sends a request such as the following: -- POST /FseInsServicesWeb/services/fseComunicazioneMetadati HTTP/1.1 -- Connection: Keep-Alive -- Content-Length: 50649 -- Content-Type: multipart/related; type="application/xop+xml"; start="<rootpart@soapui.org>"; start-info="text/xml"; boundary="----=_Part_0_355796458.1662133302632" -- Accept-Encoding: gzip,deflate -- Authorization: Basic xxxxx -- Host: ... -- SOAPAction: "http://comunicazionemetadati.wsdl.fse.ini.finanze.it/ComunicazioneMetadati" -- MIME-Version: 1.0 -- -- ------=_Part_0_355796458.1662133302632 -- Content-Type: application/xop+xml; charset=UTF-8; type="text/xml" -- Content-Transfer-Encoding: 8bit -- Content-ID: <rootpart@soapui.org> -- -- <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:com="http://comunicazionemetadatirichiesta.xsd.fse.ini.finanze.it" xmlns:tip="http://tipodaticomunicazionemetadati.xsd.fse.ini.finanze.it"> -- <soapenv:Header/> -- ... -- -- ------=_Part_0_355796458.1662133302632 -- Content-Type: text/xml; charset=Cp1252 -- Content-Transfer-Encoding: quoted-printable -- Content-ID: <CDA2LAB_190_signed.xml> -- Content-Disposition: attachment; name="CDA2LAB_190_signed.xml" -- -- <!-- INSERIRE IL RIFERIMENTO AL FOGLIO DI STILE DI AGID OPPURE INSERIRNE UN= -- ... -- -- ------=_Part_0_355796458.1662133302632-- 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 @req int -- Use "Chilkat_9_5_0.HttpRequest" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.HttpRequest', @req OUT EXEC sp_OASetProperty @req, 'HttpVerb', 'POST' EXEC sp_OASetProperty @req, 'Path', '/FseInsServicesWeb/services/fseComunicazioneMetadati' -- Chilkat will automatically generate and add a boundary string. EXEC sp_OASetProperty @req, 'ContentType', 'multipart/related; type="application/xop+xml"; start="<rootpart@soapui.org>"; start-info="text/xml"' EXEC sp_OAMethod @req, 'AddHeader', NULL, 'SOAPAction', 'some-SOAP-action' EXEC sp_OAMethod @req, 'AddHeader', NULL, 'Connection', 'Keep-Alive' EXEC sp_OAMethod @req, 'AddHeader', NULL, 'Accept-Encoding', 'gzip,deflate' EXEC sp_OAMethod @req, 'AddHeader', NULL, 'MIME-Version', '1.0' -- Chilkat will automatically add the Content-Length and Host headers. -- The "Authorization: Basic ..." header is added by setting the Login and Password and specifying Basic authentication: EXEC sp_OASetProperty @http, 'Login', '...' EXEC sp_OASetProperty @http, 'Password', '...' EXEC sp_OASetProperty @http, 'BasicAuth', 1 -- Add the 1st multipart/related sub-part, which is the SOAP envelope. DECLARE @xmlBody nvarchar(4000) SELECT @xmlBody = '<soapenv:Envelope ....' DECLARE @success int EXEC sp_OAMethod @req, 'AddStringForUpload2', @success OUT, '', '', @xmlBody, 'utf-8', 'application/xop+xml; type="text/xml"; charset=utf-8' -- Additional headers for the 1st sub-part EXEC sp_OAMethod @req, 'AddSubHeader', @success OUT, 0, 'Content-ID', '<rootpart@soapui.org>' EXEC sp_OAMethod @req, 'AddSubHeader', @success OUT, 0, 'Content-Transfer-Encoding', '8bit' EXEC sp_OAMethod @req, 'AddSubHeader', @success OUT, 0, 'Content-Disposition', '' -- Add the 2nd multipart/related sub-part, which is the signed XML DECLARE @xmlBody2 nvarchar(4000) SELECT @xmlBody2 = '<!-- INSERIRE IL RIFERIMENT ....' EXEC sp_OAMethod @req, 'AddStringForUpload2', @success OUT, 'CDA2LAB_190_signed.xml', '', @xmlBody2, 'Cp1252', 'text/xml; charset=Cp1252' -- Additional headers for the 2nd sub-part. EXEC sp_OAMethod @req, 'AddSubHeader', @success OUT, 1, 'Content-ID', '<CDA2LAB_190_signed.xml>' EXEC sp_OAMethod @req, 'AddSubHeader', @success OUT, 1, 'Content-Transfer-Encoding', 'quoted-printable' EXEC sp_OAMethod @req, 'AddSubHeader', @success OUT, 1, 'Content-Disposition', 'attachment; name="CDA2LAB_190_signed.xml"' EXEC sp_OASetProperty @http, 'FollowRedirects', 1 DECLARE @useTls int SELECT @useTls = 1 DECLARE @resp int EXEC sp_OAMethod @http, 'SynchronousRequest', @resp OUT, 'fseservicetest.sanita.finanze.it', 443, @useTls, @req EXEC sp_OAGetProperty @http, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 <> 1 BEGIN EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @http EXEC @hr = sp_OADestroy @req RETURN END DECLARE @xmlResponse int -- Use "Chilkat_9_5_0.Xml" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Xml', @xmlResponse OUT EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT EXEC sp_OAMethod @xmlResponse, 'LoadXml', @success OUT, @sTmp0 EXEC sp_OAMethod @xmlResponse, 'GetXml', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @resp EXEC @hr = sp_OADestroy @http EXEC @hr = sp_OADestroy @req EXEC @hr = sp_OADestroy @xmlResponse END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.