With RSS it is possible to distribute up-to-date web content from one web site to thousands of other web sites around the world.
RSS allows fast browsing for news and updates.
<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title>91xjr Home Page</title>
<link>https://www.91xjr.com</link>
<description>Free web building tutorials</description>
<item>
<title>RSS Tutorial</title>
<link>https://www.91xjr.com/xml/xml_rss.html</link>
<description>New RSS tutorial on 91xjr</description>
</item>
<item>
<title>XML Tutorial</title>
<link>https://www.91xjr.com/xml</link>
<description>New XML tutorial on 91xjr</description>
</item>
</channel>
</rss>
RSS was designed to show selected data.
Without RSS, users will have to check your site daily for new updates. This may be too time-consuming for many users. With an RSS feed (RSS is often called a News feed or RSS feed) they can check your site faster using an RSS aggregator (a site or program that gathers and sorts out RSS feeds).
Since RSS data is small and fast-loading, it can easily be used with services like cell phones or PDA's.
Web-rings with similar information can easily share data on their web sites to make them better and more useful.
Webmasters who seldom update their web sites do not need RSS!
RSS is useful for web sites that are updated frequently, like:
Here are some benefits of using RSS:
Choose your news
With RSS you can choose to view the news you want, the news that interest you and are relevant to your work.
Remove unwanted information
With RSS you can (finally) separate wanted information from unwanted information (spam)!
Increase your site traffic
With RSS you can create your own news channel, and publish it to the Internet!
RSS 1.0 is the only version that was developed using the W3C RDF (Resource Description Framework) standard.
The idea behind RDF was to help create a Semantic Web. However, this does not matter too much for ordinary users, but by using web standards it will be easier for persons and applications to exchange data.
RSS 0.91 and RSS 2.0 are easier to understand than RSS 1.0. Our tutorial is based on RSS 2.0.
The syntax rules of RSS 2.0 are very simple and very strict.
There is no official standard for RSS.
RSS is used to share content between websites.
With RSS, you register your content with companies called aggregators.
So, to be a part of it: First, create an RSS document and save it with an .xml extension. Then, upload the file to your website. Next, register with an RSS aggregator. Each day the aggregator searches the registered websites for RSS documents, verifies the link, and displays information about the feed so clients can link to documents that interests them.
Tip: Read our RSS Publishing chapter to view free RSS aggregation services.
RSS documents use a self-describing and simple syntax.
Here is a simple RSS document:
<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title>91xjr Home Page</title>
<link>https://www.91xjr.com</link>
<description>Free web building tutorials</description>
<item>
<title>RSS Tutorial</title>
<link>https://www.91xjr.com/xml/xml_rss.html</link>
<description>New RSS tutorial on 91xjr</description>
</item>
<item>
<title>XML Tutorial</title>
<link>https://www.91xjr.com/xml</link>
<description>New XML tutorial on 91xjr</description>
</item>
</channel>
</rss>
The first line in the document - the XML declaration - defines the XML version and the character encoding used in the document. In this case the document conforms to the 1.0 specification of XML and uses the UTF-8 character set.
The next line is the RSS declaration which identifies that this is an RSS document (in this case, RSS version 2.0).
The next line contains the <channel> element. This element is used to describe the RSS feed.
The <channel> element has three required child elements:
Each <channel> element can have one or more <item> elements.
Each <item> element defines an article or "story" in the RSS feed.
The <item> element has three required child elements:
Finally, the two last lines close the <channel> and <rss> elements.
The syntax for writing comments in RSS is similar to that of HTML:
<!-- This is an RSS comment -->
Because RSS is XML, keep in mind that:
The RSS <channel> element describes the RSS feed.
Look at the following RSS document:
<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title>91xjr Home Page</title>
<link>https://www.91xjr.com</link>
<description>Free web building tutorials</description>
<item>
<title>RSS Tutorial</title>
<link>https://www.91xjr.com/xml/xml_rss.html</link>
<description>New RSS tutorial on 91xjr</description>
</item>
</channel>
</rss>
As mentioned before, the <channel> element describes the RSS feed, and has three required child elements:
The <channel> element usually contains one or more <item> elements. Each <item> element defines an article or "story" in the RSS feed.
Furthermore, there are several optional child elements of <channel>. We will explain the most important ones below.
The <category> child element is used to specify a category for your feed.
The <category> element makes it possible for RSS aggregators to group sites based on category.
The category for the RSS document above could be:
<category>Web development</category>
The <copyright> child element notifies about copyrighted material.
The copyright for the RSS document above could be:
<copyright>2006 Refsnes Data as. All rights reserved.</copyright>
The <image> child element allows an image to be displayed when aggregators present a feed.
The <image> element has three required child elements:
The image for the RSS document above could be:
<image>
<url>https://www.91xjr.com/images/logo.gif</url>
<title>91xjr.com</title>
<link>https://www.91xjr.com</link>
</image>
The <language> child element is used to specify the language used to write your document.
The <language> element makes it possible for RSS aggregators to group sites based on language.
The language for the RSS document above could be:
<language>en-us</language>
Each <item> element defines an article or "story" in an RSS feed.
Look at the following RSS document:
<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title>91xjr Home Page</title>
<link>https://www.91xjr.com</link>
<description>Free web building tutorials</description>
<item>
<title>RSS Tutorial</title>
<link>https://www.91xjr.com/xml/xml_rss.html</link>
<description>New RSS tutorial on 91xjr</description>
</item>
</channel>
</rss>
As mentioned before, each <item> element defines an article or "story" in the RSS feed.
The <item> element has three required child elements:
Furthermore, there are several optional child elements of <item>. We will explain the most important ones below.
The <author> child element is used to specify the e-mail address of the author of an item.
Note: To prevent spam e-mails, some developers do not include the <author> element.
The author of the item in the RSS document above could be:
<author>hege@refsnesdata.no</author>
The <comments> child element allows an item to link to comments about that item.
A comment of the item in the RSS document above could be:
<comments>https://www.91xjr.com/comments</comments>
The <enclosure> child element allows a media-file to be included with an item.
The <enclosure> element has three required attributes:
A media-file included in the item in the RSS document above could be:
<enclosure url="https://www.91xjr.com/xml/rss.mp3"
length="5000" type="audio/mpeg" />
Having an RSS document is not useful if other people cannot reach it.
Now it's time to get your RSS file up on the web. Here are the steps:
1. Name your RSS file. Notice that the file must have an .xml extension.
2. Validate your RSS file
3. Upload the RSS file to your web directory on your web server.
4. Copy the little orange or button to your web directory.
5. Put the little orange "RSS" or "XML" button on the page where you will offer RSS to the world (e.g. on your home page). Then add a link to the button that links to the RSS file. The code will look something like this:
<a href="https://www.91xjr.com/xml/myfirstrss.xml">
<img src="https://www.91xjr.com/xml/pic_rss.gif" width="36" height="14">
</a>.
6. Submit your RSS feed to the RSS Feed Directories (you can Google or Yahoo for "RSS Feed Directories"). Note! The URL to your feed is not your home page, it is the URL to your feed, like "https://www.91xjr.com/xml/myfirstrss.xml".
7. Register your feed with the major search engines:
8. Update your feed - After registering your RSS feed, you must make sure that you update your content frequently and that your RSS feed is constantly available.
The best way to ensure your RSS feed works the way you want, is to manage it yourself.
However, this can be very time consuming, especially for pages with lot of updates.
An alternative is to use a third-party automated RSS.
For users who only need an RSS feed for their personal website, some of the most popular blog (Web Log) managers that offer built-in RSS services are:
An RSS Reader is used to read RSS Feeds!
RSS readers are available for many different devices and OS.
There are a lot of different RSS readers. Some work as web services, and some are limited to windows (or Mac, PDA or UNIX):
Tip: Most browsers have a built-in RSS Reader. If you go to a web site that offers RSS feeds, you will see an RSS icon in the address bar, or toolbar. Click on the icon to view a list of the different feeds. Choose the feed you want to read.
Click on the little or button next to the RSS feed you want to read. Copy The URL you get in the browser window and paste it in your RSS reader.
The links in the "Element" column point to more information about each specific element.
Element | Description |
---|---|
<category> | Optional. Defines one or more categories for the feed |
<cloud> | Optional. Register processes to be notified immediately of updates of the feed |
<copyright> | Optional. Notifies about copyrighted material |
<description> | Required. Describes the channel |
<docs> | Optional. Specifies a URL to the documentation of the format used in the feed |
<generator> | Optional. Specifies the program used to generate the feed |
<image> | Optional. Allows an image to be displayed when aggregators present a feed |
<language> | Optional. Specifies the language the feed is written in |
<lastBuildDate> | Optional. Defines the last-modified date of the content of the feed |
<link> | Required. Defines the hyperlink to the channel |
<managingEditor> | Optional. Defines the e-mail address to the editor of the content of the feed |
<pubDate> | Optional. Defines the last publication date for the content of the feed |
<rating> | Optional. The PICS rating of the feed |
<skipDays> | Optional. Specifies the days where aggregators should skip updating the feed |
<skipHours> | Optional. Specifies the hours where aggregators should skip updating the feed |
<textInput> | Optional. Specifies a text input field that should be displayed with the feed |
<title> | Required. Defines the title of the channel |
<ttl> | Optional. Specifies the number of minutes the feed can stay cached before refreshing it from the source |
<webMaster> | Optional. Defines the e-mail address to the webmaster of the feed |
Element | Description |
---|---|
<author> | Optional. Specifies the e-mail address to the author of the item |
<category> | Optional. Defines one or more categories the item belongs to |
<comments> | Optional. Allows an item to link to comments about that item |
<description> | Required. Describes the item |
<enclosure> | Optional. Allows a media file to be included with the item |
<guid> | Optional. Defines a unique identifier for the item |
<link> | Required. Defines the hyperlink to the item |
<pubDate> | Optional. Defines the last-publication date for the item |
<source> | Optional. Specifies a third-party source for the item |
<title> | Required. Defines the title of the item |