Ich habe eine veraltete VB6-Anwendung, die .NET-DLL aufrufen muss, um einen WCF-Webdienst aufzurufen.VB6 ruft WCF auf: Konnte das Endpunktelement
Zuerst habe ich diese lästige Nachricht:
nicht Endpunktelement und Vertrag ‚CODSRef.DocumentMetadataType‘ mit dem Namen ‚DocumentMetadataPortSOAP12‘ finden kann in dem Servicemodel Client Konfigurationsabschnitt. Dies liegt möglicherweise daran, dass für Ihre Anwendung keine Konfigurationsdatei gefunden wurde oder dass kein Endpunktelement mit dem Namen im Clientelement gefunden wurde.
folgte ich diesen Link - Using app.config with Interop Controls - und es hat mir geholfen, meine VB6 Test exe Arbeits erhalten:
1) eine app.config von einem Netto-Test-Client kopiert
2) es Umbenannt MyVb6Test.exe.config
(derselbe Name wie die VB6-Exe).
So weit, so gut.
aktuelles Problem:
Der eigentliche Kunde ist ein VB6.exe, die einen VB6-DLL aufruft, die den .NET/COM-aware DLL ruft:
MyLegacyVb6App.exe
+-> MyNewVB6plugin.dll
+-> MyNewdotNet.dll
+-> WCF
Auch wenn ich MyLegacyVb6App.exe.config
erstellt - genau wie der Arbeits VB6 Test - ich bin immer noch
Hier ist der Code .Net in „MyNewDotNet.dll“ „Endpunktelement nicht mit dem Namen‚DocumentMetadataPortSOAP12‘... finden kann“:
DocNotificationRequesttype wsRequest = new DocNotificationRequesttype();
DocumentMetadataTypeClient wsClient = new DocumentMetadataTypeClient("DocumentMetadataPortSOAP12", m_wsUrl);
DocNotificationResponsetype wsResponse = wsClient.DocNotification(wsRequest);
F: Gibt es einen Grund, warum ich eigentlich eine "app.config" brauche? Gibt es eine Möglichkeit, dass ich direkt in meinem C# -Code "hart codieren" kann, was immer es benötigt?
F: Welche anderen Alternativen habe ich für mein Szenario: VB6 exe -> VB6 .dll -> .Net/Interop .dll => WCF
???
Vielen Dank im Voraus!
Ich vermute, dass Ihre .NET DLL die Konfigurationsdatei nicht lesen kann. Sie müssen eine Codeänderung für den .NET-DLL-Quellcode vornehmen, damit er seine eigene Konfigurationsdatei lesen kann. – abhi