Welcome!

Industrial IoT Authors: Don MacVittie, Elizabeth White, Stackify Blog, Yeshim Deniz, SmartBear Blog

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>
...
<entry>
...
</entry>
<entry>
 <id>http://stackoverflow.com/q/00000000</id>
 <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"/>
 <author>
  <name>anonymous</name>
  <uri>http://stackoverflow.com/users/000000</uri>
 </author>
 <link rel="alternate" href="http://stackoverflow.com/questions/00000000/windows-store-xml-data" />
 <published>1900-01-01T00:00:00Z</published>
 <updated>1900-01-01T00:00:00Z</updated>
 <summary type="html">
  <p>How do I use XML in Windows Phone apps?</p>
 </summary>
</entry>
<entry>
...
</entry>
...
</feed>

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();

 conn.setRequestMethod("GET");

 conn.setDoInput(true);

 conn.connect();

 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
results.Add(feedEntry);

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;

 parser.ParseAsync();
}

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
"Space Monkey by Vivent Smart Home is a product that is a distributed cloud-based edge storage network. Vivent Smart Home, our parent company, is a smart home provider that places a lot of hard drives across homes in North America," explained JT Olds, Director of Engineering, and Brandon Crowfeather, Product Manager, at Vivint Smart Home, in this SYS-CON.tv interview at @ThingsExpo, held Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA.
"Akvelon is a software development company and we also provide consultancy services to folks who are looking to scale or accelerate their engineering roadmaps," explained Jeremiah Mothersell, Marketing Manager at Akvelon, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA.
In his session at 21st Cloud Expo, Carl J. Levine, Senior Technical Evangelist for NS1, will objectively discuss how DNS is used to solve Digital Transformation challenges in large SaaS applications, CDNs, AdTech platforms, and other demanding use cases. Carl J. Levine is the Senior Technical Evangelist for NS1. A veteran of the Internet Infrastructure space, he has over a decade of experience with startups, networking protocols and Internet infrastructure, combined with the unique ability to it...
Gemini is Yahoo’s native and search advertising platform. To ensure the quality of a complex distributed system that spans multiple products and components and across various desktop websites and mobile app and web experiences – both Yahoo owned and operated and third-party syndication (supply), with complex interaction with more than a billion users and numerous advertisers globally (demand) – it becomes imperative to automate a set of end-to-end tests 24x7 to detect bugs and regression. In th...
"IBM is really all in on blockchain. We take a look at sort of the history of blockchain ledger technologies. It started out with bitcoin, Ethereum, and IBM evaluated these particular blockchain technologies and found they were anonymous and permissionless and that many companies were looking for permissioned blockchain," stated René Bostic, Technical VP of the IBM Cloud Unit in North America, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Conventi...
Large industrial manufacturing organizations are adopting the agile principles of cloud software companies. The industrial manufacturing development process has not scaled over time. Now that design CAD teams are geographically distributed, centralizing their work is key. With large multi-gigabyte projects, outdated tools have stifled industrial team agility, time-to-market milestones, and impacted P&L stakeholders.
"Cloud Academy is an enterprise training platform for the cloud, specifically public clouds. We offer guided learning experiences on AWS, Azure, Google Cloud and all the surrounding methodologies and technologies that you need to know and your teams need to know in order to leverage the full benefits of the cloud," explained Alex Brower, VP of Marketing at Cloud Academy, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clar...
Widespread fragmentation is stalling the growth of the IIoT and making it difficult for partners to work together. The number of software platforms, apps, hardware and connectivity standards is creating paralysis among businesses that are afraid of being locked into a solution. EdgeX Foundry is unifying the community around a common IoT edge framework and an ecosystem of interoperable components.
"MobiDev is a software development company and we do complex, custom software development for everybody from entrepreneurs to large enterprises," explained Alan Winters, U.S. Head of Business Development at MobiDev, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA.
Coca-Cola’s Google powered digital signage system lays the groundwork for a more valuable connection between Coke and its customers. Digital signs pair software with high-resolution displays so that a message can be changed instantly based on what the operator wants to communicate or sell. In their Day 3 Keynote at 21st Cloud Expo, Greg Chambers, Global Group Director, Digital Innovation, Coca-Cola, and Vidya Nagarajan, a Senior Product Manager at Google, discussed how from store operations and ...
"There's plenty of bandwidth out there but it's never in the right place. So what Cedexis does is uses data to work out the best pathways to get data from the origin to the person who wants to get it," explained Simon Jones, Evangelist and Head of Marketing at Cedexis, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA.
SYS-CON Events announced today that CrowdReviews.com has been named “Media Sponsor” of SYS-CON's 22nd International Cloud Expo, which will take place on June 5–7, 2018, at the Javits Center in New York City, NY. CrowdReviews.com is a transparent online platform for determining which products and services are the best based on the opinion of the crowd. The crowd consists of Internet users that have experienced products and services first-hand and have an interest in letting other potential buye...
SYS-CON Events announced today that Telecom Reseller has been named “Media Sponsor” of SYS-CON's 22nd International Cloud Expo, which will take place on June 5-7, 2018, at the Javits Center in New York, NY. Telecom Reseller reports on Unified Communications, UCaaS, BPaaS for enterprise and SMBs. They report extensively on both customer premises based solutions such as IP-PBX as well as cloud based and hosted platforms.
It is of utmost importance for the future success of WebRTC to ensure that interoperability is operational between web browsers and any WebRTC-compliant client. To be guaranteed as operational and effective, interoperability must be tested extensively by establishing WebRTC data and media connections between different web browsers running on different devices and operating systems. In his session at WebRTC Summit at @ThingsExpo, Dr. Alex Gouaillard, CEO and Founder of CoSMo Software, presented ...
WebRTC is great technology to build your own communication tools. It will be even more exciting experience it with advanced devices, such as a 360 Camera, 360 microphone, and a depth sensor camera. In his session at @ThingsExpo, Masashi Ganeko, a manager at INFOCOM Corporation, introduced two experimental projects from his team and what they learned from them. "Shotoku Tamago" uses the robot audition software HARK to track speakers in 360 video of a remote party. "Virtual Teleport" uses a multip...
A strange thing is happening along the way to the Internet of Things, namely far too many devices to work with and manage. It has become clear that we'll need much higher efficiency user experiences that can allow us to more easily and scalably work with the thousands of devices that will soon be in each of our lives. Enter the conversational interface revolution, combining bots we can literally talk with, gesture to, and even direct with our thoughts, with embedded artificial intelligence, whic...
SYS-CON Events announced today that Evatronix will exhibit at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Evatronix SA offers comprehensive solutions in the design and implementation of electronic systems, in CAD / CAM deployment, and also is a designer and manufacturer of advanced 3D scanners for professional applications.
Leading companies, from the Global Fortune 500 to the smallest companies, are adopting hybrid cloud as the path to business advantage. Hybrid cloud depends on cloud services and on-premises infrastructure working in unison. Successful implementations require new levels of data mobility, enabled by an automated and seamless flow across on-premises and cloud resources. In his general session at 21st Cloud Expo, Greg Tevis, an IBM Storage Software Technical Strategist and Customer Solution Architec...
To get the most out of their data, successful companies are not focusing on queries and data lakes, they are actively integrating analytics into their operations with a data-first application development approach. Real-time adjustments to improve revenues, reduce costs, or mitigate risk rely on applications that minimize latency on a variety of data sources. In his session at @BigDataExpo, Jack Norris, Senior Vice President, Data and Applications at MapR Technologies, reviewed best practices to ...
An increasing number of companies are creating products that combine data with analytical capabilities. Running interactive queries on Big Data requires complex architectures to store and query data effectively, typically involving data streams, an choosing efficient file format/database and multiple independent systems that are tied together through custom-engineered pipelines. In his session at @BigDataExpo at @ThingsExpo, Tomer Levi, a senior software engineer at Intel’s Advanced Analytics gr...