{"id":35,"date":"2007-10-19T22:24:09","date_gmt":"2007-10-19T20:24:09","guid":{"rendered":"http:\/\/joergnapp.de\/2007\/10\/19\/nutzung-des-soap-servers-mit-office\/"},"modified":"2014-06-13T00:24:18","modified_gmt":"2014-06-12T22:24:18","slug":"nutzung-des-soap-servers-mit-office","status":"publish","type":"post","link":"https:\/\/joergnapp.de\/blog\/nutzung-des-soap-servers-mit-office\/","title":{"rendered":"Nutzung des SOAP-Servers mit Office"},"content":{"rendered":"<p>Ich wollte noch auf die Nutzung des <a href=\"http:\/\/joergnapp.de\/2007\/08\/30\/ein-einfacher-soap-server-in-php\/\">SOAP-Servers<\/a> mit Word (2000) hinaus.<\/p>\n<h2>Nutzung mit dem SOAP-Toolkit von Microsoft<\/h2>\n<p>Diese \u00e4lteren Office-Versionen haben im Gegensatz zur Methode mit .net keinen  direkten Zugriff auf die <acronym title=\"Simple Object Access Protocol\">SOAP<\/acronym>-Methoden. Dies l\u00e4sst sich  aber mit <a href=\"http:\/\/msdn2.microsoft.com\/en-us\/webservices\/aa740662.aspx\" rel=\"nofollow\">Microsofts SOAP-Toolkit<\/a> nachr\u00fcsten. Microsoft schreibt zwar,  dass das Toolkit durch .net veraltet sei, bietet aber sowohl <a href=\"http:\/\/www.microsoft.com\/downloads\/details.aspx?familyid=c943c0dd-ceec-4088-9753-86f052ec8450\" rel=\"nofollow\">das komplette SDK<\/a> wie auch <a href=\"http:\/\/www.microsoft.com\/downloads\/details.aspx?familyid=BA611554-5943-444C-B53C-C0A450B7013C\" rel=\"nofollow\">das verteilbare Paket<\/a> zum Download an.<\/p>\n<p>Damit wird die Nutzung des Webservices ziemlich einfach. Unter Extras-Verweise mu\u00df ein Verweis zum Microsoft SOAP Toolkit hinzugef\u00fcgt werden.<\/p>\n<p>In der Prozedur ben\u00f6tigen wir zun\u00e4chst ein entsprechendes Objekt:<\/p>\n<pre lang=\"vb\" line=\"1\">\r\n    Dim soap As SoapClient\r\n    Set soap = New SoapClient\r\n<\/pre>\n<p>Mit diesem Objekt wird die WSDL-Datei abgeholt. Im Anschluss daran stehen die per Web-Service ver\u00f6ffentlichten Funktionen als Methoden des Objekts zur Verf\u00fcgung. F\u00fcr uns hei\u00dft das:<\/p>\n<pre lang=\"vb\" line=\"1\">\r\n    With soap\r\n        ' Hole die Funktionen aus der Beschreibungsdatei\r\n        .mssoapinit \"http:\/\/www.example.com\/soapserver.php?wsdl.\"\r\n\r\n        ' Und jetzt tu was...\r\n        ergebnis = .suche(\"Suchbegriff\")\r\n    End With\r\n<\/pre>\n<p>Dabei scheint es wichtig zu sein, im nuSoap einen Namespace zu verwenden. Ohne Namespace-Definition erhalte ich einen VB-Fehler, mit keinen.<\/p>\n<h3>Nutzung von PocketSOAP<\/h3>\n<p>Eine weitere nette Bibliothek ist <a href=\"http:\/\/www.pocketsoap.com\/\">PocketSOAP<\/a> von Simon Fell. Nachdem man auch hier unter  <kbd>Extras<\/kbd>&#8211;<kbd>Verweise<\/kbd> diese Bibliothek hinzugef\u00fcgt hat, holt  folgende Code die Suchergebnisse ab:<\/p>\n<pre lang=\"vb\" line=\"1\">\r\n    Dim SOAP As New CoEnvelope\r\n    Dim HTTP As New HTTPTransport\r\n    Dim Result() As String\r\n\r\n    With SOAP\r\n        .MethodName = \"suche\"\r\n        .Parameters.Create \"sucheRequest\", \"Suchbegriff\"\r\n    End With\r\n\r\n    HTTP.Send \"http:\/\/www.example.com\/soapserver.php\", SOAP.Serialize\r\n\r\n    ' parse the SOAP message\r\n    SOAP.Parse HTTP\r\n\r\n    ' extract the return value\r\n    Result = SOAP.Parameters.Item(0).Value\r\n<\/pre>\n<p>Noch einfacher geht des mit dem \u201e<acronym title=\"Simple Object Access Protocol\">SOAP<\/acronym> Proxy\u201c-Object: Hier gen\u00fcgen  folgende Zeilen:<\/p>\n<pre lang=\"vb\" line=\"1\">\r\n    Dim SOAPProxy As PSPROXYLib.CoSoapFactory\r\n    Dim SOAP As Object\r\n    Dim Result() As String\r\n\r\n    Set SOAPProxy = New PSPROXYLib.CoSoapFactory\r\n    Set SOAP = SOAPProxy.CreateProxy(\"http:\/\/www.example.com\/soapserver.php\")\r\n    Result = SOAP.suche(sucheRequest:=\"Suchbegriff\")\r\n<\/pre>\n<p>Zu PocketSOAP gibt es der\u00fcber hinaus einen <a href=\"http:\/\/www.pocketsoap.com\/wsdl\/\" rel=\"nofollow\">WSDL-Proxygenerator<\/a>, der  aus einer WSDL-Datei entsprechende Klassen f\u00fcr <acronym title=\"Visual Basic\">VB<\/acronym> generiert. Damit stehen die \u00fcber <acronym title=\"Simple Object Access Protocol\">SOAP<\/acronym> exportierten Funktionen als  Methoden dieser Objekte zur Verf\u00fcgung, was das Arbeiten mit diesen nat\u00fcrlich  sehr angenehm macht.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Ich wollte noch auf die Nutzung des SOAP-Servers mit Word (2000) hinaus. Nutzung mit dem SOAP-Toolkit von Microsoft Diese \u00e4lteren Office-Versionen haben im Gegensatz zur Methode mit .net keinen direkten Zugriff auf die SOAP-Methoden. Dies l\u00e4sst sich aber mit Microsofts SOAP-Toolkit nachr\u00fcsten. Microsoft schreibt zwar, dass das Toolkit durch .net veraltet sei, bietet aber sowohl &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/joergnapp.de\/blog\/nutzung-des-soap-servers-mit-office\/\" class=\"more-link\"><span class=\"screen-reader-text\">\u201eNutzung des SOAP-Servers mit Office\u201c <\/span>weiterlesen<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[11,14,17,15,4,12,182],"class_list":["post-35","post","type-post","status-publish","format-standard","hentry","category-allgemein","tag-office","tag-php","tag-pocketsoap","tag-soap","tag-visual-basic","tag-webservices","tag-word"],"_links":{"self":[{"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/posts\/35","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/comments?post=35"}],"version-history":[{"count":0,"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/posts\/35\/revisions"}],"wp:attachment":[{"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/media?parent=35"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/categories?post=35"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/joergnapp.de\/blog\/wp-json\/wp\/v2\/tags?post=35"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}