Solved

WCF Service call SOAP request

Posted on 2016-07-22
15
86 Views
Last Modified: 2016-08-31
I built a WCF Service that uses custom username and password authentication and I am testing it from the client app with the following code:

    using (ServiceReferenceClient.TestServiceClient tc = new ServiceReferenceClient.TestServiceClient())
    {
    	tc.ClientCredentials.ServiceCertificate.Authentication.CertificateValidationMode = X509CertificateValidationMode.None;
        tc.ClientCredentials.UserName.UserName = "User1";
        tc.ClientCredentials.UserName.Password = "Pwd1";
        tc.ServiceMethod(param1, param2, param3);
    }

Open in new window


It works fine but I need to see the actual SOAP request sent to the WCF service and response. How can I do that from my client?
0
Comment
Question by:YZlat
  • 6
  • 6
  • 2
15 Comments
 
LVL 75

Expert Comment

by:käµfm³d 👽
ID: 41725484
Run Fiddler while you send requests. It will show you the HTTP traffic, including the SOAP.
0
 
LVL 35

Author Comment

by:YZlat
ID: 41727778
That's the thing, my client app does not make http requests so it does not show up in fiddler
0
 
LVL 75

Expert Comment

by:käµfm³d 👽
ID: 41727916
What do you mean your client does not make the requests? If this is an SSL-secured service, then you'll have to enable Fiddler's SSL interception, which will require installing a self-signed cert that Fiddler uses to decrypt traffic. (Basically, Fiddler performs a man-in-the middle "attack" allowing you to see the SSL-encrypted data.)
0
ScreenConnect 6.0 Free Trial

Discover new time-saving features in one game-changing release, ScreenConnect 6.0, based on partner feedback. New features include a redesigned UI, app configurations and chat acknowledgement to improve customer engagement!

 
LVL 35

Author Comment

by:YZlat
ID: 41741081
The client app is a console application in Visual studio. I open Fiddler and then run the client app and nothing shows up in fiddler
0
 
LVL 8

Expert Comment

by:Randy Peterson
ID: 41748914
Have you tried using Wireshark?  What is the endpoint of your WCF service you are consuming?  I am just curious what protocol you are using for the connection.
0
 
LVL 35

Author Comment

by:YZlat
ID: 41749081
I am using wsdl endpoint
0
 
LVL 8

Expert Comment

by:Randy Peterson
ID: 41749132
OK.  But the wsdl endpoint means you added it as a service reference in the project correct?  Look in your app.config and you will find the actual endpoint (URL).  Can you post the xml here?
0
 
LVL 35

Author Comment

by:YZlat
ID: 41768832
Here is what I have in Web.config file of the client:

<client>
      <endpoint address="http://localhost:xxxxx/MyService.svc" binding="wsHttpBinding"
        bindingConfiguration="wsHttpEndpoint" contract="ServiceReference1.IMyService"
        name="wsHttpEndpoint">
        <identity>
          <certificate encodedValue="xxxxxx" />
        </identity>
      </endpoint>
    </client>

Open in new window

0
 
LVL 8

Expert Comment

by:Randy Peterson
ID: 41769015
Author just responded.  Now we can try to answer the question.
0
 
LVL 8

Accepted Solution

by:
Randy Peterson earned 500 total points
ID: 41769033
So looking at your endpoint it appears that your are hosting this on IIS correct?  Also, your client is on the same server correct?   Getting loopback packets are not so simple.  So you can install the client on a different machine and then you can easily capture the packets based on ip to ip, or you can follow the instructions here to get local loopback traffic captured:  https://wiki.wireshark.org/CaptureSetup/Loopback
0
 
LVL 35

Author Comment

by:YZlat
ID: 41774667
Yes, the service is hosted on IIS server but the client is on a different server
0
 
LVL 8

Assisted Solution

by:Randy Peterson
Randy Peterson earned 500 total points
ID: 41774974
So, that makes it easier then.  Open up wireshark and do a simple filter on the other compter's ip address.  You should even be able to filter on the particular port so you only see that traffic.  Although, just an FYI, if you have security set up, your messages could be encrypted (at least the inner packet.
0
 
LVL 35

Author Comment

by:YZlat
ID: 41776401
I am not familiar with wireshark and I cannot install something that is not in approved software list due to security reasons. Is there anything else I could use?
0
 
LVL 8

Expert Comment

by:Randy Peterson
ID: 41776565
Unfortunately, that is the only one I have been using.  It is the one software I've found that really captures the packets, which is really what you are after.  As suggesting other software, I'm not familiar with others and it would most likely be in the same situation with your ability to install.  I would suggest if seeing the actual packets is a must, then try to get approval for wireshark.  You do not get to see the actual soap message in your client or service as it is all handled in the network stack.

Here is the wireshark tutorial to capture the SOAP messages:  https://victorjabur.com/2010/09/10/capturing-soap-message-through-http-traffic-web-services/
0

Featured Post

3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

While working on Silverlight and WCF application, I faced one issue where fault exception occurred at WCF operation contract is not getting propagated to Silverlight client. So after searching net I came to know that it was behavior by default for s…
Entity Framework is a powerful tool to help you interact with the DataBase but still doesn't help much when we have a Stored Procedure that returns more than one resultset. The solution takes some of out-of-the-box thinking; read on!
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…

825 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question