RSS 是返察缺一种“轻量级、多用途、可扩展的元数据描述及联合推广格式”,也可以理解为一种规范。它本身是一种 XML 格式,用于为内容整合客户端提供选择性的、汇总过的 Web 内容。如今,许多站点都开始通过创建 RSS feed 向浏览者提供内容整合服务,提供新闻、站点内容的更新等等。浏览者可以通过一些客户端软件方便地得到这些组织、汇总了的信息。
那么,怎么在我们自己的网站上创建 RSS feed 呢?下面我以 Asp+Access 为例介绍一下。
既然 RSS 是一种 XML 格式的文档,那么我们就应当可以对后台数据库中的数据按照条件没大进行筛选、组织,然后通过 ASP 生成 XML 格式的数据流,最后发送到客户端进行浏览。
数据的选取、汇集是 Asp 的拿手好戏,关键在于漏辩怎么生成 XML 格式的数据流。其实 Asp 也已经有自己的解决办法,就是在写数据前对 response 对象的ContentType 属性进行定义。如果 response.ContentType 的取值为 "text/xml",就会向浏览者发送 XML 格式的数据流。
在 IE 浏览器中调用 RSS 源的方法和普通的链接没有什么区别,格式是:
a type="application/rss+xml" href="RssFeed.asp"RSS说明/a
其中 type="application/rss+xml" 加不加好象没有什么区别。
以下程序段是创建我的网站“十万个为什么”(上的“技术新闻”栏目的 RSS feed 的源代码,文件名为 RssFeed_news.asp。
其中,变量 sXmlClear 用于声明产生的文档是一段 XML 格式的文档,该声明是可选的,以保持与旧版本 XML 的向后兼容性。
sRssHead 定义 Rss 的基本元素。RSS feed 通常由 4 个主要元素构成:channel,l timage,item 和 textinput。其中,channel 元素是必需的,item 元素至少要出现一次。textinput 和 image 元素是可选的,是否使用要视具体情况而定。
channel 元素包含 Channel(RSS feed 的来源)的一个简单描述。title 是频道的名称/标题;link 是与频道内容对应的包含了完整内容的那个网页的 URL;description 是与 channel 的内容有关的简单描述;language 代表语言。还有一些别的属性,不是太常用。
item 元素用于对数据库中的记录进行描述。item 一般有若干项,对应了一个 Rss feed 的数据集合。
!-Filename:RssFeed_news.asp:--
% Option explicit %
!-- #include file="./conn.inc" --
%
Dim sSQL, rs, sCrLf, sXmlClear, sRssHead, sRssEnd
sCrLf = chr(13) chr(10) ’回车+换行
sXmlClear = "?xml version=’1.0’ encoding=’gb2312’?" sCrLf
sRssHead = "rss version=’2.0’" sCrLf
sRssHead = sRssHead "channel" sCrLf
sRssHead = sRssHead "title Why100000 /title" sCrLf
sRssHead = sRssHead "description Why100000 /description" sCrLf
sRssHead = sRssHead "link/link" sCrLf
sRssHead = sRssHead "languagezh-cn/language" sCrLf
sRssHead = sRssHead "docsWhy100000.COM News Center/docs" sCrLf
sRssHead = sRssHead "generatorRss Generator By /generator" sCrLf
sRssEnd = "/channel/rss"
Response.CharSet="gb2312" ’数据集
Response.ContentType="text/xml" ’数据流格式定义
’输出:
Response.write sXmlClear
Response.write sRssHead
sSQL="select top 15 * from news order by sortid desc"
Set rs = Server.CreateObject("ADODB.Recordset")
rs.Open sSQL, s_Conn, 1, 1
if not (rs.eof and rs.bof) then
do while not rs.eof
response.write "item" sCrLf
response.write "title " rs("f_topic") " /title" sCrLf
response.write "link " ""
rs("f_i_autoid") " /link" sCrLf
response.write "author " rs("f_author") " /author" sCrLf
response.write "pubDate " rs("f_datetime") " /pubDate" sCrLf
response.write "/item" sCrLf sCrLf
rs.movenext
loop
end if
rs.close
set rs=nothing
Response.write sRssEnd
%
连缺或早接数据库:<%
set conn=server.CreateObject("adodb.connection")
conn.open "driver={Microsoft Access Driver (*.mdb)}dbq="&server.MapPath("database\messages.mdb")/数据库表名
set rs=server.CreateObject("adodb.recordset")
%>
登陆
<!--#include file="conn.asp"-->
<% name1=Request.Form("name1")
password=Request.Form("password")
%>
<%sql="SELECT * FROM admins "
Set Rs=conn.Execute(sql)
if name1=rs("name1") and password=rs("password") Then
response.Redirect("login.asp")
end if
%>
验证name和pass:
<script language="JavaScript">
function CheckForm()
{
if (document.denglu.name1.value.length == 0)
{
alert("请输入用户名.")
document.denglu.name1.focus()
return false
}
if (document.denglu.name1.value.indexOf("<")!=-1 || document.denglu.name1.value.indexOf(">"伏雀)!=-1)
{
alert("用户名中包含非法字符 (<,>) ")
document.denglu.name1.focus()
return false
}
if (document.denglu.name1.value.indexOf("'团樱")!=-1)
{
alert("用户名中包含非法字符 (') ")
document.denglu.name1.focus()
return false
}
if (document.denglu.password.value.length == 0)
{
alert("请输入密码.")
document.denglu.password.focus()
return false
}
return true
}
</script>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)