views:

199

answers:

4

i got a problem.

suppose on the other side, the WSDL will be always changed,

for example, the web service on the otherside which descriped in the WSDL file has only method, but the name of the method might always change, today call methodABC(), tomorrow will be change to methodDEFO()..

suppose in JAVA, is there anyway, i can dynamically generate the web service client, without manually do it by hand??? i mean dynamically generate the client when my application is still running..

or what kind of article should i go and have a look, coz i do a lots of search from the internet, cannot find a way to do it..i think i might need to create my own framework to handle it..but don`t know where to start.

A: 

Well,

there's a couple of questions to ask about this one:

1.: Does you application 'know' the actual i.e. the changed name of the method at runtime?

2.: Are you in controll of that web service?

3.: What framework do you use for the WS communication?

K

KB22
no...i have no control on the otherside..that is why i am trying to create a dynamic client generator...if i can control the other side..i won`t have such problem...the framework now i am using is asix2
shrimpy
thats no good. the stubs will most likely not work once the method name has changed. is there a pattern for the name changes? i.e. can your app guess from the new wsdl what the actual method name is?
KB22
A: 

Generally wsdl is the file which is like a contract between the consumer and the host. If that is going to change dynamically, you need to understand the repurcussions of this change than dynamically consuming the service.

Kalpak
hmm...i have no way...i have to use that wsdl file......and i think it should possible for me to do it..coz the method name in the file already define in the WSDL file, the data type also been defined in the WSDL file...and i get from know from somewhere that which method should i invoke to by using what kind of logic........
shrimpy
All things like return type, signature and method names are written in wsdl. My point of asking the question was if the return type or signature changes to some object you don't have, then you will need to generate them too which will be another overhead.If you can tell the exact scenario, a better solution can be reached.
Kalpak
+3  A: 

You can use any WSDL-to-Java tool in conjunction with the Java Compiler API, load the generated classes with a URLClassLoader, and get going. Quite a bit of work, but not very hard, I'd say. (You may run out of permgen space eventually, though.)

However, if your scenario is reality, the most important question would not be how to generate the classes, but why is the publisher of the web service on crack?

Edit: To clarify the "on crack" thingie. Changing the interface of the web service (e.g., a method name) means that you'll have to guess which method to call. If there's only one method in the interface, it is admittedly not that hard to figure out which method to call, but still - what happens if suddenly TWO methods pop up in there?

Changing the interface of a service used by external systems is a Really Big Thing, and should not be taken lightly. It should most definitely be automated. It is one heck of a code smell, and most likely a sign of incompetence, substance abuse and/or sheer insanity.

I realize my moralizing like this doesn't solve your problem. I just hope you can talk someone responsible into understanding that a web service constantly changing its interface is, well, an abomination, and that it would be better to have that changed, than adapting your code to it.

gustafc
'on crack', LOL - that web-service has gotta be a candidate for WTF if ever I've seen one...
Nick Holt
I'm tempted to +1 this just for the crack comment. :)
R. Bemrose
+1 for the 'crack' comment's shock value
day_trader
A: 

Web services of this sort where the WSDL changes dynamically are not suitable for generated client bindings.

Most web service stacks support the concept of a dynamic clients, where you invoke the web service operations in a less static way.

To pick one example, see the relevant part of the Apache CXF dopcumentation.

Another example, is Spring-WS, which never uses WSDL-generated code, but instead is XML document-centric. If you have highly changeable web services, then I would strongly recommend Spring-WS over the more "traditional" JAX-WS generated client.

skaffman