Webservices about-web-services

Definitie van Adobe Campaign API's definition-of-adobe-campaign-apis

De Adobe Campaign-toepassingsserver is ontworpen voor openheid en eenvoudige integratie met steeds meer uiteenlopende en complexe bedrijfsinformatiesystemen.

Adobe Campaign API's worden gebruikt in JavaScript binnen de toepassing en in SOAP daarbuiten. Ze vormen een bibliotheek van generieke functies die kunnen worden verrijkt. Zie voor meer informatie SOAP-methoden implementeren.

IMPORTANT
Het aantal geoorloofde Vraag van de Motor varieert per dag op uw vergunningscontract. Raadpleeg deze pagina voor meer informatie.
Een lijst met alle API's, inclusief de volledige beschrijving ervan, is beschikbaar in [deze speciale documentatie] (https://experienceleague.adobe.com/developer/campaign-api/api/index.html?lang=nl-NL.

Vereisten prerequisites

Voordat u de Adobe Campaign API's kunt gebruiken, moet u vertrouwd zijn met de volgende onderwerpen:

  • Javascript
  • SOAP-protocol
  • Adobe Campaign datamodel

Adobe Campaign API's gebruiken using-adobe-campaign-apis

Adobe Campaign gebruikt twee typen API's:

Om APIs te ontwikkelen en met Adobe Campaign in wisselwerking te staan, moet u met uw datamodel vertrouwd zijn. Met Adobe Campaign kunt u een volledige beschrijving van de basis genereren. Zie Beschrijving van het model.

SOAP-aanroepen soap-calls

Het protocol van de ZEEP laat u API methodes, via de rijke cliënt, derdetoepassingen aanhalen gebruikend webservices, of JSP gebruikend deze methodes.

De structuur van een SOAP-bericht is als volgt:

  • een omhulsel dat de structuur van het bericht aangeeft;
  • een optionele koptekst,
  • een instantie die de informatie over de oproep en de reactie bevat;
  • foutbeheer dat de foutvoorwaarde definieert.

Middelen en uitwisselingen resources-and-exchanges

In het volgende schema ziet u de verschillende bronnen die betrokken zijn bij het gebruik van Adobe Campaign API's:

Voorbeeld van een SOAP-bericht bij de methode 'ExecuteQuery' example-of-a-soap-message-on-the--executequery--method--

In dit voorbeeld, roept een vraag van de ZEEP de "ExecuteQuery"methode aan, die een karakterkoord als parameter voor authentificatie (zittingsteken) en een inhoud van XML voor de beschrijving van de uit te voeren vraag neemt.

Zie voor meer informatie ExecuteQuery (xtk:queryDef).

NOTE
De beschrijving van WSDL van deze dienst wordt voltooid in het hier getoonde voorbeeld: Webservicebeschrijving: WSDL.

SOAP-query soap-query

<?xml version='1.0' encoding='ISO-8859-1'?>
  <SOAP-ENV:Envelope xmlns:xsd='http://www.w3.org/2001/XMLSchema' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xmlns:ns='http://xml.apache.org/xml-soap' xmlns:SOAP-ENV='http://schemas.xmlsoap.org/soap/envelope/'>
    <SOAP-ENV:Body>
      <ExecuteQuery xmlns='urn:xtk:queryDef' SOAP-ENV:encodingStyle='http://schemas.xmlsoap.org/soap/encoding/'>
        <__sessiontoken xsi:type='xsd:string'/>
        <entity xsi:type='ns:Element' SOAP-ENV:encodingStyle='http://xml.apache.org/xml-soap/literalxml'>
          <queryDef firstRows="true" lineCount="200" operation="select" schema="nms:rcpGrpRel" startLine="0" startPath="/" xtkschema="xtk:queryDef">
          ...
          </queryDef>
        </entity>
      </ExecuteQuery>
  </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

De <soap-env:envelope> element is het eerste element van het bericht dat de envelop van de ZEEP vertegenwoordigt.

De <soap-env:body> element is het eerste onderliggende element van de envelop. Het bevat de beschrijving van het bericht, d.w.z. de inhoud van de vraag of de reactie.

De methode die moet worden aangeroepen, wordt ingevoerd in het <executequery> -element uit de hoofdtekst van het SOAP-bericht.

In SOAP worden de parameters op volgorde van weergave herkend. De eerste parameter, <__sessiontoken>, neemt de authentificatieketen, is de tweede parameter de beschrijving van XML van de vraag van <querydef> element.

SOAP-reactie soap-response

<?xml version='1.0' encoding='ISO-8859-1'?>
  <SOAP-ENV:Envelope xmlns:xsd='http://www.w3.org/2001/XMLSchema' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xmlns:ns='http://xml.apache.org/xml-soap' xmlns:SOAP-ENV='http://schemas.xmlsoap.org/soap/envelope/'>
    <SOAP-ENV:Body>
      <ExecuteQueryResponse xmlns='urn:xtk:queryDef' SOAP-ENV:encodingStyle='http://schemas.xmlsoap.org/soap/encoding/'>
        <pdomOutput xsi:type='ns:Element' SOAP-ENV:encodingStyle='http://xml.apache.org/xml-soap/literalxml'>
          <rcpGrpRel-collection><rcpGrpRel group-id="1872" recipient-id="1362"></rcpGrpRel></rcpGrpRel-collection>
        </pdomOutput>
      </ExecuteQueryResponse>
    </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

Het resultaat van de query wordt ingevoerd vanuit het <pdomoutput> element.

Foutbeheer error-management

Voorbeeld van reactie SOAP-fout:

<?xml version='1.0' encoding='ISO-8859-1'?>
<SOAP-ENV:Envelope xmlns:SOAP-ENV='http://schemas.xmlsoap.org/soap/envelope/'>
  <SOAP-ENV:Body>
    <SOAP-ENV:Fault>
      <faultcode>SOAP-ENV:Server</faultcode>
      <faultstring>Error while executing 'Write' of the 'xtk:persist'.</faultstring> service
      <detail>ODBC error: [Microsoft][ODBC SQL Server Driver][SQL Server]Cannot insert duplicate key row in object 'XtkOption' with unique index 'XtkOption_name'. SQLSTate: 23000
ODBC error: [Microsoft][ODBC SQL Server Driver][SQL Server]The statement has been terminated. SQLSTate: 01000 Cannot save the 'Options (xtk:option)' document </detail>
    </SOAP-ENV:Fault>
  </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

De <soap-env:fault> -element in de hoofdtekst van het SOAP-bericht wordt gebruikt om de foutsignalen over te brengen die optreden tijdens de verwerking van de webservice. Dit bestaat uit de volgende subelementen:

  • <faultcode> : geeft het type fout aan. De fouttypen zijn:

    • "VersionMismatch" in geval van incompatibiliteit met de gebruikte SOAP-versie,
    • "MustUnderstanding" in geval van een probleem in de berichtkopbal,
    • "Client" in het geval dat de client enige informatie mist,
    • "Server" in het geval dat de server een probleem heeft met het uitvoeren van de verwerking.
  • <faultstring> : bericht waarin de fout wordt beschreven

  • <detail> : lang foutbericht

Het succes of de mislukking van de de dienstaanroeping wordt geïdentificeerd wanneer <faultcode> element is geverifieerd.

IMPORTANT
Alle Adobe Campaign-webservices verwerken fouten. Daarom wordt sterk geadviseerd om elke vraag te testen om teruggekeerde fouten te behandelen.

Voorbeeld van foutafhandeling in C#:

try
{
  // Invocation of method
  ...
}
catch (SoapException e)
{
  System.Console.WriteLine("Soap exception: " + e.Message);
  if (e.Detail != null)
    System.Console.WriteLine(e.Detail.InnerText);
}

URL van de de dienstserver van het Web (of EndPoint) url-of-web-service-server--or-endpoint-

Om de dienst van het Web voor te leggen, moet de server van Adobe Campaign die de overeenkomstige de dienstmethode uitvoert worden gecontacteerd.

De server-URL is als volgt:

https://serverName/nl/jsp/soaprouter.jsp

Met <server> de Adobe Campaign-toepassingsserver (nlserver-web).

recommendation-more-help
601d79c3-e613-4db3-889a-ae959cd9e3e1