zoukankan      html  css  js  c++  java
  • 浅析CMS内容管理系统的两种方案

    目前市面上成熟的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文件了。

  • 相关阅读:
    BZOJ 1191 HNOI2006 超级英雄hero
    BZOJ 2442 Usaco2011 Open 修建草坪
    BZOJ 1812 IOI 2005 riv
    OJ 1159 holiday
    BZOJ 1491 NOI 2007 社交网络
    NOIP2014 D1 T3
    BZOJ 2423 HAOI 2010 最长公共子序列
    LCA模板
    NOIP 2015 D1T2信息传递
    数据结构
  • 原文地址:https://www.cnblogs.com/sntetwt/p/2046789.html
Copyright © 2011-2022 走看看