Solved

calling web service with XML output

Posted on 2011-03-06
7
672 Views
Last Modified: 2012-08-14
I need to make 1000+ calls to the following web service and download the XML output that results from each call - http://comtrade.un.org/ws/

I am fairly new to web services, so please bear with me.

I wrote some C# code with which I can call the web service - see attached.

Now, I need to call the web service with a couple of parameters - http://comtrade.un.org/ws/get.aspx?cc=TOTAL&px=S3&r=372&y=2006&p=4,%208,%2024&rg=1,2&so=9999

I will need to loop through various values for  "cc" and "r".

The web service returns a XML file which I plan to import into Excel.

Can someone please help me with the code that will help me download the files?

thanks.
namespace comtradedata
{
    class Program
    {
        static void Main(string[] args)
        {
            StringBuilder sbSource;

            // Create the web request  
            HttpWebRequest request
                = WebRequest.Create("http://comtrade.un.org/ws/") as HttpWebRequest;

            request.Proxy = WebProxy.GetDefaultProxy();         

            // Get response  
            using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
            {
                // Get the response stream  
                StreamReader reader = new StreamReader(response.GetResponseStream());

                // Read it into a StringBuilder  
                sbSource = new StringBuilder(reader.ReadToEnd());

                // Console application output  
                Console.WriteLine(sbSource.ToString());  
                Console.ReadLine();
            } 
        }
    }
}

Open in new window

0
Comment
Question by:IUAATech
7 Comments
 
LVL 1

Expert Comment

by:lalitgada
Comment Utility
0
 
LVL 9

Accepted Solution

by:
mayank_joshi earned 400 total points
Comment Utility
add the following code after:-
 // Read it into a StringBuilder  
 sbSource = new StringBuilder(reader.ReadToEnd());


 
 Response.Clear();
  Response.AddHeader("content-disposition", "attachment;filename=FileName.xls");
  Response.Charset = "";
 
  // If you want the option to open the Excel file without saving then
  // comment out the line below
  Response.Cache.SetCacheability(HttpCacheability.NoCache);
  Response.ContentType = "application/vnd.xls"; 
  Response.Write(sbSource.ToString());
  Response.End();

Open in new window

0
 
LVL 9

Expert Comment

by:gery128
Comment Utility
I think,
You should use XML classes available in .NET (like XMLDocument, XMLTextReader) to parse the response stream in XML and then you can convert your XML in Excel.
you should also check the HttpResponse's StatusCode property to know if the response status (i.e. check for 200)
0
Threat Intelligence Starter Resources

Integrating threat intelligence can be challenging, and not all companies are ready. These resources can help you build awareness and prepare for defense.

 
LVL 9

Expert Comment

by:gery128
Comment Utility
Forget to add example code of XmlTextReader:
using System.Xml;  
  
// Retrieve XML document  
XmlTextReader reader = new XmlTextReader("Your WEB-SERVICE URL");  
  
// Skip non-significant whitespace  
reader.WhitespaceHandling = WhitespaceHandling.Significant;  
  
// Read nodes one at a time  
while (reader.Read())  
{  
    // Print out info on node  
   //do some operations.
}  

Open in new window

0
 

Author Comment

by:IUAATech
Comment Utility
I am trying mayank_joshi's approach.

Which namespace should I use for "Response" and HttpCacheability? I already have a reference to System.Web namespace in my code.
0
 
LVL 9

Assisted Solution

by:gery128
gery128 earned 100 total points
Comment Utility
HttpCacheability is an enum which comes under System.Web. So you should get it if you are importing that namespace. Try full namespace name, System.Web.HttpCacheability.
Also for Response, you may be trying to use Response in demo console application you have created. Response is the property of the System.Web.UI.Page class, If you try it in ASP.NET application it will work. Response is not available in a Console Application as there is no HttpContext.
You may try WebClient class to generate request and get response in console application, but you will get response string only you won't be able to generate Excel file using System.Web.UI.Page.Response.
Check out this link:
WebClient in Console Application
Which type of application are you targeting? ASP.NET or Console Application (executable) ? If Console Application then, you need to change your approach related to Response.
0
 

Author Comment

by:IUAATech
Comment Utility
thanks gery128 - yeah, I am targeting a console app and I got it to work. thanks.
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

This article introduced a TextBox that supports transparent background.   Introduction TextBox is the most widely used control component in GUI design. Most GUI controls do not support transparent background and more or less do not have the…
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
It is a freely distributed piece of software for such tasks as photo retouching, image composition and image authoring. It works on many operating systems, in many languages.
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…

762 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

Need Help in Real-Time?

Connect with top rated Experts

8 Experts available now in Live!

Get 1:1 Help Now