Consuming RSS feeds in an ASP.NET page

I like reading Scott Guthrie's blog. Trouble is, I get so busy, I forget to go over there and have a look to see what's new. I was searching for something the other day, and stumbled across someone else's blog (I forget whose), but I noticed that they had the 5 most recent items in Scott's blog embedded in their home page. It was only then that I discovered that Scott Mitchell has written a whole load more tutorials on Data Access, and that these have been available for a while. So I got to thinking that I should add a feed from Scott G's site onto the home page here, so I can be updated more quickly. Here's the bare bones of how I did it.

The first thing I did was to create a static method that would return a string.

public static string ProcessRSS(string rssURL, string feed)

The method takes two strings - the url of the feed and a string containing the name of the feed. Next, I use System.Net.HttpRequest to obtain the text of the feed, and load it into an in-memory XML document. RSS is after all, a form of XML.

{
  WebRequest request = WebRequest.Create(rssURL);
  WebResponse response = request.GetResponse();
  StringBuilder sb = new StringBuilder("");
  Stream rssStream = response.GetResponseStream();
  XmlDocument rssDoc = new XmlDocument();
  rssDoc.Load(rssStream);

I only need part of the information in the RSS feed - the bits within the "item" element (or node), and within that, I need just the "title" and "link" elements. I use the SelectNodes() method to obtain the "item" nodes, which is then held in an XmlNodeList collection. I decided to limit the number of items in my feed to 5, so I check the Count property of the collection, and set an upper limit for my iteration loop.

  XmlNodeList rssItems = rssDoc.SelectNodes("rss/channel/item");

  string title = "";
  string link = "";
  int upperlimit = rssItems.Count;
  if (upperlimit > 5)
    upperlimit = 5;
  if (upperlimit > 0)
  {
    sb.Append("<p>" + feed + "</p><ul>");
    for (int i = 0; i < upperlimit; i++)

Now I reference the individual nodes - title and link - as XmlNode objects. These are acquired using the SelectSingleNode() method of the XmlNodeList, which takes an XPath expression as an argument. The XPath expression is the name of the node to be acquired. Once the node has been referenced, I take it's InnerText property (how similar is all this to working with the DOM in Javascript and the getElementById method?!?) and build a string, which is ultimately returned by the method.

	
    {
      XmlNode rssDetail;
      rssDetail = rssItems.Item(i).SelectSingleNode("title");
      if (rssDetail != null)
      {
         title = rssDetail.InnerText;
      }
      else
      {
        title = "";
      }

      rssDetail = rssItems.Item(i).SelectSingleNode("link");
      if (rssDetail != null)
      {
        link = rssDetail.InnerText;
      }
      else
      {
        link = "";
      } 
      sb.Append("<li><a href='" + link + "' target='_blank'>" + title + "</a></li>");
    }
    sb.Append("</ul>");
  }
return sb.ToString();
}

For each feed that I want to include on my page, all I need to do now is add a Literal control, and in code-behind, set its Text property to the string returned by the method:

Feed1.Text = ProcessRSS("http://weblogs.asp.net/scottgu/rss.aspx", "ScottGu");

Date Posted: Saturday, August 18, 2007 11:12 PM
Last Updated: Saturday, May 22, 2010 7:52 PM
Posted by: Mikesdotnetting
Total Views to date: 11844

1 Comment

Thursday, April 18, 2013 6:49 PM - michael Acker

Nice Example.
Add your comment

If you have any comments to make about this article, please use this form to do so. Make sure that your comment relates specifically to the article above. More general comments can be posted through the form on the Contact page.

Please note, all comments are moderated, and some may not be published. The kind of things that will ensure your comment is deleted without ever seeing the light of day are as follows:

  • Not relevant to the article
  • Gratuitous links to your own site or product
  • Anything abusive or libellous
  • Spam
  • Anything in a language I don't understand including gibberish.

I do not pass email addresses on to spammers, so a valid one will assist me in responding to you personally if required.

Recent Comments

Bino 11/27/2014 7:05 PM
In response to MVC 5 with EF 6 in Visual Basic - Async and Stored Procedures with the Entity Framework
Copy +...

Manas 11/27/2014 5:30 AM
In response to Scheduled Tasks In ASP.NET With Quartz.Net
Hi Mike, Thank you for awesome article. My concern is it might impact website if we use or is...

priya 11/26/2014 6:50 PM
In response to Create PDFs in ASP.NET - getting started with iTextSharp
very nice.....its save my time...

ransems 11/24/2014 12:29 AM
In response to Adding A Controller
Love the article. I dislike that the world thinks c# articles are the way to go. Love the VB, keep...

Gautam 11/20/2014 8:01 AM
In response to I'm Writing A Book On WebMatrix
Hello Mike, I read your book, loved it! However, I have a few request/suggestions: 1) an example...

Bret Dev 11/19/2014 8:39 PM
In response to The Difference Between @Helpers and @Functions In WebMatrix
Excellent post! One concern - where can you place global @Functions code within an MVC project to Is...

Rob Farquharson 11/19/2014 4:28 PM
In response to iTextSharp - Links and Bookmarks
How can I place text at an absolute position on the page? Also, how can I rotate text?...

Andy 11/17/2014 8:08 PM
In response to MVC 5 with EF 6 in Visual Basic - Sorting, Filtering and Paging
Hello I'm testing your sorting instructions above. This is great and I was able to get it to work...

Gautam 11/17/2014 5:51 PM
In response to WebMatrix - Database Helpers for IN Clauses
Hi Mike, I am very new to programming: In the above example if I want to use a delete button the...

donramon 11/17/2014 3:22 PM
In response to Entity Framework 6 Recipe - Alphabetical Paging In ASP.NET MVC
Congratulations on your new website look and the excellent articles. Thank you!...