关于ASP.NET读取XML新闻的问题
2009-03-07 21:51
429 查看
单位需要更新一下以前的新闻系统,需要与现代社会接轨,因此开始研究了一下XML来存储新闻的方法。
找到了网上流传的一段很有名的读取XML文件作为新闻的方法,代码如下:
<%@ Import Namespace="System"%>
<%@ Page Language="C#" Debug="true" codepage="936"%>
<%@ Import Namespace="System.IO" %>
<%@ Assembly Name="System.Xml" %>
<%@ Import Namespace="System.Xml.Xsl" %>
<html>
<head>
<title>
</title>
<script language="c#" runat="server">
public string xslt()
{
StringWriter writer = new StringWriter();
XmlDocument xmldoc= new XmlDocument();
xmldoc.Load(Server.MapPath(Request["name"] +".xml"));
XslTransform xsldoc = new XslTransform();
xsldoc.Load(Server.MapPath("main.xsl"));
DocumentNavigator nav= new DocumentNavigator(xmldoc);
xsldoc.Transform(nav,null,writer);
return writer.ToString();
}
</script>
</head>
<body>
<%=xslt()%>
<p align="center">该程序由<a href="http://www.aspcool.com">www.aspcool.com</a>设计制作.</p>
</body>
</html>
关键的地方就是:
DocumentNavigator nav= new DocumentNavigator(xmldoc);
这句话怎么都不能解释,郁闷了很久,找了最新的MSDN Lib结果找到一个2001年的MSDN 杂志上面的一段话:
DocumentNavigator只能用于Asp.Net Beta2,痛苦,找了老半天,这段所谓经典的代码竟然是过时的产品。
没有办法,只好从后一句想办法,找
xsldoc.Transform(nav,null,writer);
总算找到了Transform这个函数的用法,
public XmlReader Transform(
XPathNavigator input,
XsltArgumentList args
);
然后就开始找XPathNavigator,不错,XmlDocument自己就带了一个CreateNavigator()函数。
总算大功告成。
修改后的代码:
<%@ Import Namespace="System"%>
<%@ Page Language="C#" Debug="true" codepage="936"%>
<%@ Import Namespace="System.IO" %>
<%@ Assembly Name="System.Xml" %>
<%@ Import Namespace="System.Xml" %>
<%@ Import Namespace="System.Xml.Xsl" %>
<%@ Import Namespace="System.Xml.XPath" %>
<html>
<head>
<title>
</title>
<script language="c#" runat="server">
public string xslt()
{
StringWriter writer = new StringWriter();
XmlDocument xmldoc= new XmlDocument();
xmldoc.Load(Server.MapPath(Request["name"] +".xml"));
XslTransform xsldoc = new XslTransform();
xsldoc.Load(Server.MapPath("main.xsl"));
XPathNavigator nav = xmldoc.CreateNavigator();
xsldoc.Transform(nav,null,writer);
return writer.ToString();
}
</script>
</head>
找到了网上流传的一段很有名的读取XML文件作为新闻的方法,代码如下:
<%@ Import Namespace="System"%>
<%@ Page Language="C#" Debug="true" codepage="936"%>
<%@ Import Namespace="System.IO" %>
<%@ Assembly Name="System.Xml" %>
<%@ Import Namespace="System.Xml.Xsl" %>
<html>
<head>
<title>
</title>
<script language="c#" runat="server">
public string xslt()
{
StringWriter writer = new StringWriter();
XmlDocument xmldoc= new XmlDocument();
xmldoc.Load(Server.MapPath(Request["name"] +".xml"));
XslTransform xsldoc = new XslTransform();
xsldoc.Load(Server.MapPath("main.xsl"));
DocumentNavigator nav= new DocumentNavigator(xmldoc);
xsldoc.Transform(nav,null,writer);
return writer.ToString();
}
</script>
</head>
<body>
<%=xslt()%>
<p align="center">该程序由<a href="http://www.aspcool.com">www.aspcool.com</a>设计制作.</p>
</body>
</html>
关键的地方就是:
DocumentNavigator nav= new DocumentNavigator(xmldoc);
这句话怎么都不能解释,郁闷了很久,找了最新的MSDN Lib结果找到一个2001年的MSDN 杂志上面的一段话:
DocumentNavigator只能用于Asp.Net Beta2,痛苦,找了老半天,这段所谓经典的代码竟然是过时的产品。
没有办法,只好从后一句想办法,找
xsldoc.Transform(nav,null,writer);
总算找到了Transform这个函数的用法,
public XmlReader Transform(
XPathNavigator input,
XsltArgumentList args
);
然后就开始找XPathNavigator,不错,XmlDocument自己就带了一个CreateNavigator()函数。
总算大功告成。
修改后的代码:
<%@ Import Namespace="System"%>
<%@ Page Language="C#" Debug="true" codepage="936"%>
<%@ Import Namespace="System.IO" %>
<%@ Assembly Name="System.Xml" %>
<%@ Import Namespace="System.Xml" %>
<%@ Import Namespace="System.Xml.Xsl" %>
<%@ Import Namespace="System.Xml.XPath" %>
<html>
<head>
<title>
</title>
<script language="c#" runat="server">
public string xslt()
{
StringWriter writer = new StringWriter();
XmlDocument xmldoc= new XmlDocument();
xmldoc.Load(Server.MapPath(Request["name"] +".xml"));
XslTransform xsldoc = new XslTransform();
xsldoc.Load(Server.MapPath("main.xsl"));
XPathNavigator nav = xmldoc.CreateNavigator();
xsldoc.Transform(nav,null,writer);
return writer.ToString();
}
</script>
</head>
相关文章推荐
- 发发牢骚,关于ASP.NET读取XML新闻的问题
- 关于ASP.NET读取XML新闻的问题
- [ZT]关于ASP.NET读取XML新闻的问题
- ASP.NET中关于XML的AJAX的读取与删除
- 关于asp.net unity框架结构无法读取配置节“unity”问题处理办法
- 关于asp.net MVC发布后,网站无法读取数据库的问题
- 在asp.net mvc中使用百度UEditor初始化内容遇到自数据库中读取的html字符串在UEditor中始终是html编码的问题
- 关于AJAX跨域调用ASP.NET MVC或者WebAPI服务的问题及解决方案
- 关于.net读取xml的问题
- 关于ASP.NET在IIS中一些问题的经验总结
- asp.net如何读取xml文件中的数据
- asp.net c# 如何读取XML文件里的CDATA里的HTML
- 一个关于UrlReferrer的小问题 (asp.net 1.1)
- Asp.net关于获取客户端CPU,硬盘,MAC序列号的问题
- js生成的cookie由asp.net读取的时候中文乱码问题的解决
- ASP.NET读取XML文件4种方法
- 关于ASP.net中服务器控件的脚本问题
- 关于asp.net 2.0 入门学习之“GlobalResources与Callback问题”的笔记
- ASP.NET关于分页上的数据删除问题
- asp.net简单读取xml文件信息