Re: 2. (It requires me to put out two sets of interfaces), what do you mean by interfaces? The wsdl itself? Otherwise why different interfaces?
We had the same problem, and decided to have the wsdl's merged into one, containing one service and several port(types). We use Java2WSDL to generate the wsdl's, and after generating the first wsdl use the --input parameter to import that for creating the second wsdl and so on. Then the modify the namespaces of the operations in final wsdl to allow having methods with the same signature in different porttypes. When reading this wsdl with .NET, it sees every porttype as a different service, but puts all services/classes in one reference. This allows the services to use the same classes. Axis WSDL2Java also handles the big wsdl, and generates classes/stubs for every porttype. So you can have operations with the same signature in different porttypes, and have the same interface in one wsdl as in several wsdl's. I agree it is not the best to have one big wsdl, but the only way I could find to handle properly and easily in .NET. If possible it might be a solution to only share primitive types between services. - Arent-Jan -----Original Message----- From: Anand Natrajan [mailto:[EMAIL PROTECTED] Sent: Tuesday, June 29, 2004 7:14 PM To: [EMAIL PROTECTED] Subject: Re: .NET client accessing multiple Axis WSDLs Re: specify the same namespace, do you mean within the WSDLs itself? I already do specify the same namespace for the common data structure, and it doesn't work. Re: specify the same namespace, do you mean within VB? Tried that, but VB won't let you do it. It's sort of like trying to specify two variables with the same name in the same scope - malformed. Re: merge all the WSDLs, yes, it is possible, and I am considering it, but the solution is a bit unpleasant. 1. It nullifies the careful separation I have crafted of grouping related operations in each WSDL. 2. It requires me to put out two sets of interfaces - one consisting of a single merged WSDL for .NET clients, the other consisting of multiple WSDL files for all other clients. 3. It requires me to resolve operation names that happen to have the same signature but different function in different WSDLs. 4. Because of #3, I can't simply have the Java interface class corresponding to the merged WSDL inherit from the Java interfaces classes corresponding to the separate WSDLs. Therefore, it's up to me (and future developers) to ensure that the two sets of interfaces stay consistent. Thanks for responding though! Although your suggestion isn't ideal, it's still the best I've got, and it made me think. (: Anand On Tue, 29 Jun 2004, Vy Ho wrote: : Is it possible to merge all your wsdls into a same wsdl file? Or : specify a same namespace for all of them? : : : Anand Natrajan wrote: : : >Hello! : > : >As part of my .NET and Axis interoperability work, I am facing a piquant : >situation. I have written multiple web services using Axis. Each of these : >web services defines a particular complex data structure called Principal. : >The definition, XML namespace and package name for this structure are : >identical in each WSDL generated for my services. I have written Axis-based : >Java clients and SOAP::Lite-based Perl clients that invoke operations from : >multiple WSDLs within the same program. Call these clients "cross-WSDL : >clients" - they work perfectly, especially when I have to pass the same : >instance of Principal to different operations. : > : >Now, I'd like to write cross-WSDL .NET clients. I am using Visual Studio : >.NET, and using Visual Basic to write such a client. Here, I face a : >namespace issue in the client. In order to invoke operations in a WSDL from : >a VB client, I have to import the WSDL as a web reference. When I do so, : >.NET gives the WSDL a name, somewhat similar to a package name in Java. : >Different WSDLs get different names. However, because of this practice, I : >end up with multiple definitions of Principal viz., WSDL1.Principal and : >WSDL2.Principal. Now, I find I cannot use a single instance of Principal to : >invoke operations from different WSDLs. VB's type-checking system forces me : >to use WSDL1.Principal when invoking operations defined in WSDL1 and : >WSDL2.Principal when invoking operations defined in WSDL2. : > : >Recall, these multiple definitions are actually identical. Because of the : >way .NET imports and names WSDLs, I am forced to create multiple instances : >for the same principal and keep them consistent. How can I avoid doing so? : > : >I have tried defining Principal in a common schema file and : >importing/including it into each WSDL - that has no effect. Thinking through : >it, I realise that it cannot have any effect because .NET will continue to : >give different names to each WSDL, whether or not the WSDLs happen to import : >other schema files. I also tried tinkering with the namespace of Principal, : >to no avail. : > : >I have tried adding the schema file as a web reference, but that fails : >because .NET wants a WSDL, not an XSD file. Backing off from the schema : >approach, I tried casting WSDL1.Principal into a WSDL2.Principal, but .NET : >refused to sanction that. Is there anything else I can try? Has anyone : >encountered this situation before? : > : >Thank you for any help, and for even reading this. I will peruse this group : >regularly for any response, but I'd also appreciate a copy sent to : >[EMAIL PROTECTED] : > : >Anand Natrajan