Industrial IoT Authors: Elizabeth White, Stackify Blog, Yeshim Deniz, SmartBear Blog, Liz McMillan

Blog Feed Post

Android to Windows Phone 8: Parse XML data

Now that your app can connect to a network and manage its network usage, it’s time to start working with data. Two of the most common data formats in use on the Internet today are Extensible Markup Language (XML) and JavaScript Object Notation (JSON). Website that update their content frequently, such as blogs, often provide an XML feed so that apps can keep up with the content changes. This section will show you how to parse an XML document and use its data in your apps.

The first thing you’ll need to do is decide on an XML feed you want to use in your app. For this section will use a feed from StackOverflow.com that focuses on Windows 8. The feed is available at http://stackoverflow.com/feeds/tag/windows-phone-8.

Once you’ve identified the feed you’ll want to analyze it to determine which fields are of interest to your app. Below is a sample abstract form the StackOverflow.com feed we’ll be using:

<?xml version="1.0" encoding="utf-8"?>
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:creativeCommons="http://backend.userland.com/creativeCommonsRssModule" xmlns:re="http://purl.org/atompub/rank/1.0">
<title type="text">active questions tagged windows-phone-8 - Stack Overflow</title>
 <re:rank scheme="http://stackoverflow.com">0</re:rank>
 <title type="text">Windows Phone XML Data</title>
 <category scheme="http://stackoverflow.com/feeds/tag/windows-phone-8/tags" term="c#"/>
 <category scheme="http://stackoverflow.com/feeds/tag/windows-phone-8/tags" term="xml"/>
 <category scheme="http://stackoverflow.com/feeds/tag/windows-phone-8/tags" term="windows-8"/>
 <category scheme="http://stackoverflow.com/feeds/tag/windows-phone-8/tags" term="windows-runtime"/>
 <link rel="alternate" href="http://stackoverflow.com/questions/00000000/windows-store-xml-data" />
 <summary type="html">
  <p>How do I use XML in Windows Phone apps?</p>

For the example, we’ll focus on the title, link, and summary elements. The first step is to create a class that represents the data you want to work with in your app. Since we’re focusing on the title, link, and summary elements of the feed, the class will look like the following:

public class FeedEntry
 public string Title { get; set; }

 public string Link { get; set; }

 public string Summary { get; set; }

The next step is to create a class and a method that will be responsible for the parsing:

public class StackOverflowXmlParser

Since we’ll be connecting to an internet resource to obtain the XML data we’ll want to do so asynchronously to avoid blocking other operations. Once we’ve obtained the data and parsed it into a list of FeedEntry objects we’ll raise an event to signal to the caller that the operation is complete. This can be done via the following:

public event EventHandler<List<FeedEntry>> ParseCompleted;

Next we’ll need a method that to kick off the asynchronous procedure to obtain data and parse it:

public void ParseAsync()
 var connectionState = GetConnectionState();

 if (connectionState == ConnectionState.WiFi || connectionState == ConnectionState.Ethernet)
  var request = WebRequest.CreateHttp("http://stackoverflow.com/feeds/tag/windows-8");

  request.BeginGetResponse(BeginGetResponseCallback, request);

This code does a couple of things. First it obtains the current type of Internet connection the device has. If the device is connected to a WiFi or Ethernet connection it proceeds to create an HttpWebRequest object and call its BeginGetResponse method. This begins an asynchronous request to StackOverflow for the particular feed we’re interested in. The first parameter of this method is a callback that will be invoked when the response is received. The second parameter of the call is any state we want to utilize in the callback. In this case, we want to make sure we get access to the originating HttpWebRequest, so we simple pass it through.

We’ll utilize the callback to parse the data. The first thing we’ll want to do in this method is create a list of FeedEntry objects to store the results in.

private void BeginGetResponseCallback(IAsyncResult asyncResult)
 List<FeedEntry> results = new List<FeedEntry>();

Next we need to get the response stream which contain the data we want to parse:

var request = (HttpWebRequest)asyncResult.AsyncState;

var response = request.EndGetResponse(asyncResult);

var responseStream = response.GetResponseStream();

The next thing to do is to determine the method by which the feed will be processed. Because we’re dealing with an XML feed, we have three options in .NET:

  1. The System.Xml namespace
  2. The System.Xml.Linq namespace
  3. The System.ServiceModel.Syndication namespace

The System.Xml namespace provides standards-based support for processing XML. It gives you quite a bit of control over how you process XML and allows you to use things like XSD schemas, XPath expressions, and XSLT transformations. It’s a little more power than we need for this particular task. The SyndicationFeed class in the System.ServiceModel.Syndication namespace would actually make our job incredibly simple if we wanted work with all of the fields in the feed. However, since we’re only concerned with three fields we’ll use the System.Xml.Linq namespace. This namespace contains the classes for LINQ (Language INtegrated Query) to XML which serves as an in-memory XML programming interface that enables easy and efficient processing of XML documents.

First up when working with LINQ to XML is to create some XName objects that represent the names of the elements we want to work with. These names need to include the local and namespace names.

//Atom namespace
var atomNamespace = "http://www.w3.org/2005/Atom";

//Create the names of the XML elements including the Atom namespace
var entryXName = XName.Get("entry", atomNamespace);
var titleXName = XName.Get("title", atomNamespace);
var linkXName = XName.Get("link", atomNamespace);
var summaryXName = XName.Get("summary", atomNamespace);

The next step is to load the XML data in the response stream into a new instance of the XElement class.

XElement root = XElement.Load(responseStream);
Android tip
This is similar to using Android’s HttpURLConnection to retrieve and InputStream

private InputStream downloadXml() throws IOException {

 URL url = new URL('http://stackoverflow.com/feeds/tag/windows-8');

 HttpURLConnection conn = (HttpURLConnection) url.openConnection();




 return conn.getInputStream();

You would then use the InputStream output as an input parameter into the XmlPullParser class’s setInput method.

Once the XElement object is loaded, we can use LINQ to query for just the entry elements and in the XElement and store them in a list:

//Load all "entry" elements from the XML into a list
var entries = (from e in root.Elements(entryXName) select e).ToList();

Next we’ll start iterating through the list of entries. The first step in the iteration is to instantiate a new FeedEntry object:

//Iterate all "entry" elements
foreach (var entry in entries)
 //Create a new FeedEntry
 var feedEntry = new FeedEntry();

Then we’ll assign the value of the FeedEntry’s Title property to the value of the title element:

//Get the title
var titleElement = (from e in entry.Elements(titleXName) select e).FirstOrDefault();

if (titleElement != null)
 feedEntry.Title = titleElement.Value;
Android tip
The Android equivalent would be calling the getText() method of the XmlPullParser class to get the value of the current element.

Similarly we’ll assign the value of the Link property to the value of the link element’s href attribute:

//Get the link
var linkElement = (from e in entry.Elements(linkXName) select e).FirstOrDefault();

if (linkElement != null)
 var hrefAttribute = linkElement.Attributes("href").FirstOrDefault();

 if (hrefAttribute != null)
  feedEntry.Link = hrefAttribute.Value;
Android tip
To get the attribute value in Android you would use the getAttribueValue() method of the XmlPullParser class.

Next we’ll assign the value of the Summary property to the value of the summary element and add the object to the result set to be returned to the calling method:

//Get the summary
if (summaryElement != null)
 feedEntry.Summary = WebUtility.HtmlDecode(summaryElement.Value);

//Add to the entry to the result set

Next we need to raise the event to signal to the original calling method that the parsing is complete:

if (this.ParseCompleted != null)
 this.ParseCompleted(this, results);

The last step is to call the ParseAsync method and respond the ParseCompleted event.

public void GetXmlData()
 var parser = new StackOverlfowParser();

 parser.ParseCompleted += parser_ParseCompleted;


private void parser_ParseCompleted(object sender, List<FeedEntry> e)
 //do something with the results

That’s it! Your Windows Phone application can now work with data from the Internet.

Read the original blog entry...

More Stories By Adam Grocholski

Hey there! My name is Adam Grocholski, and I'm a Technical Evangelist at Microsoft where I spend time focusing on Windows, Windows Phone, and Windows Azure. I live in the frozen tundra of Minnesota and run thinkfirstcodelater.com. You can also follow me on twitter at @codel8r.

@ThingsExpo Stories
Dion Hinchcliffe is an internationally recognized digital expert, bestselling book author, frequent keynote speaker, analyst, futurist, and transformation expert based in Washington, DC. He is currently Chief Strategy Officer at the industry-leading digital strategy and online community solutions firm, 7Summits.
Digital Transformation and Disruption, Amazon Style - What You Can Learn. Chris Kocher is a co-founder of Grey Heron, a management and strategic marketing consulting firm. He has 25+ years in both strategic and hands-on operating experience helping executives and investors build revenues and shareholder value. He has consulted with over 130 companies on innovating with new business models, product strategies and monetization. Chris has held management positions at HP and Symantec in addition to ...
Cloud-enabled transformation has evolved from cost saving measure to business innovation strategy -- one that combines the cloud with cognitive capabilities to drive market disruption. Learn how you can achieve the insight and agility you need to gain a competitive advantage. Industry-acclaimed CTO and cloud expert, Shankar Kalyana presents. Only the most exceptional IBMers are appointed with the rare distinction of IBM Fellow, the highest technical honor in the company. Shankar has also receive...
Enterprises have taken advantage of IoT to achieve important revenue and cost advantages. What is less apparent is how incumbent enterprises operating at scale have, following success with IoT, built analytic, operations management and software development capabilities - ranging from autonomous vehicles to manageable robotics installations. They have embraced these capabilities as if they were Silicon Valley startups.
The standardization of container runtimes and images has sparked the creation of an almost overwhelming number of new open source projects that build on and otherwise work with these specifications. Of course, there's Kubernetes, which orchestrates and manages collections of containers. It was one of the first and best-known examples of projects that make containers truly useful for production use. However, more recently, the container ecosystem has truly exploded. A service mesh like Istio addr...
Poor data quality and analytics drive down business value. In fact, Gartner estimated that the average financial impact of poor data quality on organizations is $9.7 million per year. But bad data is much more than a cost center. By eroding trust in information, analytics and the business decisions based on these, it is a serious impediment to digital transformation.
Predicting the future has never been more challenging - not because of the lack of data but because of the flood of ungoverned and risk laden information. Microsoft states that 2.5 exabytes of data are created every day. Expectations and reliance on data are being pushed to the limits, as demands around hybrid options continue to grow.
Business professionals no longer wonder if they'll migrate to the cloud; it's now a matter of when. The cloud environment has proved to be a major force in transitioning to an agile business model that enables quick decisions and fast implementation that solidify customer relationships. And when the cloud is combined with the power of cognitive computing, it drives innovation and transformation that achieves astounding competitive advantage.
As IoT continues to increase momentum, so does the associated risk. Secure Device Lifecycle Management (DLM) is ranked as one of the most important technology areas of IoT. Driving this trend is the realization that secure support for IoT devices provides companies the ability to deliver high-quality, reliable, secure offerings faster, create new revenue streams, and reduce support costs, all while building a competitive advantage in their markets. In this session, we will use customer use cases...
Digital Transformation: Preparing Cloud & IoT Security for the Age of Artificial Intelligence. As automation and artificial intelligence (AI) power solution development and delivery, many businesses need to build backend cloud capabilities. Well-poised organizations, marketing smart devices with AI and BlockChain capabilities prepare to refine compliance and regulatory capabilities in 2018. Volumes of health, financial, technical and privacy data, along with tightening compliance requirements by...
The IoT Will Grow: In what might be the most obvious prediction of the decade, the IoT will continue to expand next year, with more and more devices coming online every single day. What isn’t so obvious about this prediction: where that growth will occur. The retail, healthcare, and industrial/supply chain industries will likely see the greatest growth. Forrester Research has predicted the IoT will become “the backbone” of customer value as it continues to grow. It is no surprise that retail is ...
Andrew Keys is Co-Founder of ConsenSys Enterprise. He comes to ConsenSys Enterprise with capital markets, technology and entrepreneurial experience. Previously, he worked for UBS investment bank in equities analysis. Later, he was responsible for the creation and distribution of life settlement products to hedge funds and investment banks. After, he co-founded a revenue cycle management company where he learned about Bitcoin and eventually Ethereal. Andrew's role at ConsenSys Enterprise is a mul...
The best way to leverage your Cloud Expo presence as a sponsor and exhibitor is to plan your news announcements around our events. The press covering Cloud Expo and @ThingsExpo will have access to these releases and will amplify your news announcements. More than two dozen Cloud companies either set deals at our shows or have announced their mergers and acquisitions at Cloud Expo. Product announcements during our show provide your company with the most reach through our targeted audiences.
DevOpsSummit New York 2018, colocated with CloudEXPO | DXWorldEXPO New York 2018 will be held November 11-13, 2018, in New York City. Digital Transformation (DX) is a major focus with the introduction of DXWorldEXPO within the program. Successful transformation requires a laser focus on being data-driven and on using all the tools available that enable transformation if they plan to survive over the long term. A total of 88% of Fortune 500 companies from a generation ago are now out of bus...
With 10 simultaneous tracks, keynotes, general sessions and targeted breakout classes, @CloudEXPO and DXWorldEXPO are two of the most important technology events of the year. Since its launch over eight years ago, @CloudEXPO and DXWorldEXPO have presented a rock star faculty as well as showcased hundreds of sponsors and exhibitors! In this blog post, we provide 7 tips on how, as part of our world-class faculty, you can deliver one of the most popular sessions at our events. But before reading...
DXWorldEXPO LLC announced today that "Miami Blockchain Event by FinTechEXPO" has announced that its Call for Papers is now open. The two-day event will present 20 top Blockchain experts. All speaking inquiries which covers the following information can be submitted by email to [email protected] Financial enterprises in New York City, London, Singapore, and other world financial capitals are embracing a new generation of smart, automated FinTech that eliminates many cumbersome, slow, and expe...
Cloud Expo | DXWorld Expo have announced the conference tracks for Cloud Expo 2018. Cloud Expo will be held June 5-7, 2018, at the Javits Center in New York City, and November 6-8, 2018, at the Santa Clara Convention Center, Santa Clara, CA. Digital Transformation (DX) is a major focus with the introduction of DX Expo within the program. Successful transformation requires a laser focus on being data-driven and on using all the tools available that enable transformation if they plan to survive ov...
DXWordEXPO New York 2018, colocated with CloudEXPO New York 2018 will be held November 11-13, 2018, in New York City and will bring together Cloud Computing, FinTech and Blockchain, Digital Transformation, Big Data, Internet of Things, DevOps, AI, Machine Learning and WebRTC to one location.
DXWorldEXPO | CloudEXPO are the world's most influential, independent events where Cloud Computing was coined and where technology buyers and vendors meet to experience and discuss the big picture of Digital Transformation and all of the strategies, tactics, and tools they need to realize their goals. Sponsors of DXWorldEXPO | CloudEXPO benefit from unmatched branding, profile building and lead generation opportunities.
DXWorldEXPO LLC announced today that ICOHOLDER named "Media Sponsor" of Miami Blockchain Event by FinTechEXPO. ICOHOLDER give you detailed information and help the community to invest in the trusty projects. Miami Blockchain Event by FinTechEXPO has opened its Call for Papers. The two-day event will present 20 top Blockchain experts. All speaking inquiries which covers the following information can be submitted by email to [email protected] Miami Blockchain Event by FinTechEXPO also offers s...