以下是借鉴MSND的http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnaspp/html/aspnet-createrssw-aspnet.asp
这篇文章。
本文不会讲解什么是Rss Feed、它的用途、形式,结构。假如你还不太清楚,请到相关网站查看。
我想说的是用Repeater控件来创建自己的Rss聚合。
1.首先建立一个简单的数据库,数据库的建立表格如下:

建立表之后,在里面随便添加点记录,DatePublished最好把默认值设置成为Getdate()。当然也可以通过代码添加到数据库中。反正添加数据进去就可以了。
2.在vs.net中建立一个Rss.aspx文件(规范是这样的),把设计试图转向html试图。贴入以下代码:
1
<%@ Page language="c#" ContentType="text/xml" Codebehind="rss.aspx.cs" AutoEventWireup="false" Inherits="SyndicationDemo.rss" %>
2
<asp:Repeater id="rptRSS" runat="server">
3
<HeaderTemplate>
4
<rss version="2.0">
5
<channel>
6
<title>互动力工作室</title>
7
<link>http://www.cbxy.com/hdl/</link>
8
<description>
9
小钊的乱涂乱画,拿出去枪毙!
10
</description>
11
</HeaderTemplate>
12
13
<ItemTemplate>
14
<item>
15
<title><%# FormatForXML(DataBinder.Eval(Container.DataItem, "Title")) %></title>
16
<description><%# FormatForXML(DataBinder.Eval(Container.DataItem, "Description")) %></description>
17
<link>http://www.cbxy.com/hdl.aspx?ID=<%# DataBinder.Eval(Container.DataItem, "ArticleID") %></link>
18
<author><![CDATA[ <%# FormatForXML(DataBinder.Eval(Container.DataItem, "Author")) %>]]></author>
19
<pubDate><%# String.Format("{0:R}", DataBinder.Eval(Container.DataItem, "DatePublished")) %></pubDate>
20
</item>
21
</ItemTemplate>
22
23
<FooterTemplate>
24
</channel>
25
</rss>
26
</FooterTemplate>
27
</asp:Repeater>
28
注意第一行还是保留自己的原代码,其他的可以先复制。 
2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

里面有几个可能还有点不明白的,比如18行的<
从上面图示切换到察看代码。
4.呵呵,现在只要绑定Repeater控件就可以。在page_load中绑定,我相信这一步还是比较简单的。我这里选前5个最新title(也就是top 5 order by DatePublished DESC 了),也可以根据自己的需要选择多少个
1
private void Page_Load(object sender, System.EventArgs e)
2
{
3
// Connect to the Database
4
SqlConnection myConnection = new SqlConnection("Server=<Server Name>;DataBase=<DataBase Name>;User id=sa;password=;");
5
6
// Retrieve the SQL query results and bind it to the Repeater
7
const string SQL_QUERY = "SELECT TOP 5 ArticleID, Title, Author, Description, DatePublished FROM Articles ORDER BY DatePublished DESC";
8
SqlCommand myCommand = new SqlCommand(SQL_QUERY, myConnection);
9
10
myConnection.Open();
11
rptRSS.DataSource = myCommand.ExecuteReader(CommandBehavior.CloseConnection);
12
rptRSS.DataBind();
13
myConnection.Close();
14
}
修改一下链接字符串,SQL语句也是想当的简单,这时rtpRSS(Repeater的ID号)就绑定到数据库了。
2

3

4

5

6

7

8

9

10

11

12

13

14

5.最后一步了,就是先前所说的FormateForXML()这个函数,先看看代码
1
protected string FormatForXML(object input)
2
{
3
string data = input.ToString(); // cast the input to a string
4
5
// replace those characters disallowed in XML documents
6
data = data.Replace("&", "&");
7
data = data.Replace("\"", """);
8
data = data.Replace("'", "'");
9
data = data.Replace("<", "<");
10
data = data.Replace(">", ">");
11
12
return data;
13
}
他的作用主要是格式化字符串,把一些字符转换成符合xml规定的字符,比如“&”,在xml当中要以“&“这种形式显示才是正确的方法,假如是"&",它就会变成运算符了。
2

3

4

5

6

7

8

9

10

11

12

13

好了,全部的创建rss的代码写完了,这些只是基本的东西,假如想得到了解更多的知识,建议看看xml的相关书籍。
上面的代码由于是绑定到Repeater创建rss,所以效率不是很高。
过一段时间我会把我的用StringBuilder创建rss整理一下,放到blog上面,这种方法要比Repeater快。