当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 浅析CMS内容管理系统的两种方案

ASP.NET
如何在ASP.NET中使用SmtpMail发送邮件
在VB.NET中利用Split和Replace函数计算字数
Attribute应用:简化ANF自定义控件初始化过程
ASP.NET 2.0移动开发入门之使用样式
ASP.NET 2.0中使用OWC生成图表
ASP.NET 2.0中控件的简单异步回调
一个无法捕获ADO.NET Dataset的内存错误
深入解读ADO.NET2.0的十大最新特性
.Net平台下的分布式缓存设计
ASP.NET全局异常处理浅析
ASP.NET 2.0中文验证码的实现
浅析.NET平台编程语言的未来走向
.net 框架程序设计收藏
使用ASP.NET MVC Futures 中的异步Action
详解.NET中的XmlReader与XmlWriter
关于.NET中的Server push技术
asp.net页面执行机制
对比JSP和ASP.NET的存储过程
.NET 4.0不会包含System.Shell.CommandLine
ASP.NET十个有效性能优化的方法

ASP.NET 中的 浅析CMS内容管理系统的两种方案


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 123 ::
收藏到网摘: n/a

目前市面上成熟的CMS产品有很多,无外乎两种解决方案:第一种就是用XSL+XML的方式来实现客户端具体数据;第二种是生成HTML或者SHTML来实现。

设计阶段的想法是,用XSL来实现文章和内容的模版,用XML来存储数据,生成静态的HTML或SHTML。到实际应用中发现了HTML转换的问题,用XSL+XML生成HTML时,XML内容中不需要进行转化的内容,使用CDATA,在XSL文件中引用部分使用disable-output-escaping="yes",生成HTML时照样将html代码进行了解析,例如<变成了<等等,我们还要对此再进行一边转码,但是还要考虑到文章内容中如果存在<的问题,岂不乱套了。当然解决方法有,例如加上自己定制的特殊标识,然后再转码,这样生成HTML就不会有问题了。

CMS的目的就是减轻服务器的负担,自然我们可以把负载加到客户端上面,如客户端浏览器解析XSL+ XML,但是考虑到有的浏览器不支持这种形式,绝大多数都是可以解析的,如Internet Explorer、Netscape、Firefox、Mozilla、Opera等。

举个例子:

XSL文件:test.xsl

以下为引用的内容:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="html" />
<xsl:template match="/article">
 <table cellspacing="1" cellpadding="1" width="200" border="1">
  <tbody>
   <tr>
    <td><xsl:value-of select="title" /></td>
    <td><xsl:value-of select="click" /></td>
   </tr>
   <tr>
    <td><xsl:value-of select="date" /></td>
    <td><xsl:value-of select="author" /></td>
   </tr>
   <tr>
    <td><xsl:value-of select="content" disable-output-escaping="yes" /></td>
    <td>测试By GlandJacky</td>
   </tr>
  </tbody>
</table>
</xsl:template>
</xsl:stylesheet>
  XML文件:view.xml

<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="test.xsl"?>
<article>
 <id>47</id>
 <title>测试XML</title>
 <icategoryId>11</icategoryId>
 <key>测试XML</key>
 <content>
  <![CDATA[
  <table cellspacing="1" cellpadding="1" width="200" border="1">
   <tbody>
    <tr>
     <td>测试XML</td>
     <td> </td>
    </tr>
    <tr>
     <td>测试XML</td>
     <td> </td>
    </tr>
    <tr>
     <td>测试XML</td>
     <td> </td>
    </tr>
   </tbody>
  </table>
 ]]>
</content>
<author>GlandJacky</author>
<date>2006-06-20 11:38:50.823</date>
<updateBy>have not update user</updateBy>
<updateTime>have not update time</updateTime>
<click>0</click>
<fileUrl>/star/boke/1150774719245/1150774719245.htm</fileUrl>
<imageUrl>/star/boke/1150774719245/images/测试2</imageUrl>
</article>

如果浏览器支持的话,可以直接在浏览器输入xml文件的地址,看到浏览器解析过的html文件了。