Home / ASP.NET Wiki / Data Access / Web Services / Method Overloading in WebServices

Method Overloading in WebServices

 Rate It (1)

Web services are also classes just like any other .NET classes. Nevertheless they have methods marked as WebMethods that can be exposed by the WebServices to be consumed by the outside world. Apart from these WebMethods they can also have normal methods like any other classes have.


Since a web service is a class it can utilize all the OO features like method overloading. However to use this feature on WebMethods we need to do something more that is explained in this article.

Creating WebMethods:

Let us create a simple WebService that has the following overloaded methods:


public int AddNumbers(int a, int b)

public int AddNumbers(int a, int b, int c)

public decimal AddNumbers(decimal a, decimal b)

All these three methods return variants of a Added numbers to the WebClient. Let us now mark the methods as Web Methods. To achieve this apply the [WebMethod] attribute to the public methods.

[WebMethod]

public int AddNumbers(int a, int b) {     

    return a+b;

}

[WebMethod]

public int AddNumbers(int a, int b, int c) {     

    return a+b+c;

}

[WebMethod]

public decimal AddNumbers(decimal a, decimal b) {    

    return a+b;

}

This would compile fine. Run the WebService in the browser. That should give an error saying that the AddNumbers() methods use the same message name 'AddNumbers' and asking to use the MessageName property of the WebMethod.

Adding the MessageName property:

Add the MessageName property to the WebMethod attribute as shown below:

[WebMethod]

public int AddNumbers(int a, int b) {   

   return "a+b";

}

[WebMethod (MessageName="AddThreeNumbers")]

public int AddNumbers(int a, int b, int c) {   

    return a + b + c;

}

[WebMethod (MessageName="AddDecimal")]

public decimal AddNumbers(decimal a, decimal b) {  

   return a+b;

}

Now compile the WebService and run in the browser. You can see that the first method is displayed as AddNumbers wherein for the second and third method the alias we set using the MessageName property is displayed

Revision number 2, Monday, September 22, 2008 8:16:51 AM by mbanavige

Comments

When i am using the above code it is throwing an error like this. Service 'WebService3' does not conform to WS-I Basic Profile v1.1. Please examine each of the normative statement violations below. To turn off conformance check set the ConformanceClaims property on corresponding WebServiceBinding attribute to WsiClaims.None. R2304: Operation name overloading in a wsdl:portType is disallowed by the Profile. A wsdl:portType in a DESCRIPTION MUST have operations with distinct values for their name attributes. Note that this requirement applies only to the wsdl:operations within a given wsdl:portType. A wsdl:portType may have wsdl:operations with names that are the same as those found in other wsdl:portTypes. - Operation 'AddNumbers' on portType 'WebService3Soap' from namespace 'http://tempuri.org/'. - Operation 'AddNumbers' on portType 'WebService3Soap' from namespace 'http://tempuri.org/'. To make service conformant please make sure that all web methods belonging to the same binding have unique names. Please Before giving thesolutions u have to check once.

Shortcuts

Table of Contents

Top Wiki Contributors

(last 30 days)

  1. abiruban (1)