我正在运行umbraco v 4.0.3。我的Web服务器是Windows Server 2003。
我注意到,除了托管的控件之外,我的一个页面还显示了来自父节点的内容。由于该页面仅用作ascx控件的主机,因此它没有自己的内容。
节点的内容区域为空,因此我不知道该内容的来源。
我已经做了以下事情来尝试解决问题,但是没有一个导致问题页面发生变化。页面仍然存在。
当我导航到该页面时,我没有做任何更改的内容。此时,我应该得到一个404,但页面仍然加载并仍然运行宏。
此时,我无法做什么,但我猜它与IIS或Dot.Net和缓存有关。
有人知道如何解决这个问题吗?
修改
我发现如果我从构建已删除页面的模板中删除了一个XSLT宏引用,那么当删除的页面在浏览器中加载时,父页面的复制就会消失。由于这是我的主要问题,我重新创建了页面并继续。我仍然感到困惑的是为什么我删除的页面能够从多个浏览器加载。
我删除的宏用于我们网站的1,500多页中的大多数页面,并且它们都没有重现父级文档关于孩子,也不是似乎对我来说 XSLT宏可以到达XML缓存之外。我已经查看了代码,但没有看到任何对其他数据存储的引用。我承认XSLT对我来说很新鲜。
下面列出了我删除了引用的宏的代码。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE xsl:Stylesheet [ <!ENTITY nbsp " "> ]>
<xsl:stylesheet
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxml="urn:schemas-microsoft-com:xslt"
xmlns:umbraco.library="urn:umbraco.library"
xmlns:custom="urn:custom.library"
exclude-result-prefixes="msxml umbraco.library custom">
<xsl:output method="xml" omit-xml-declaration="yes"/>
<msxml:script language="C#" implements-prefix="custom">
public System.Xml.XPath.XPathNodeIterator SplitMultiPageText(string unsplitText,
string pageDelimeter) {
System.Xml.XmlDocument xmlDoc = new System.Xml.XmlDocument();
string[] splitPages = System.Text.RegularExpressions.Regex.Split(unsplitText, pageDelimeter);
System.Xml.XmlElement pagesElement = xmlDoc.CreateElement("pages");
foreach (string page in splitPages) {
System.Xml.XmlElement pageElement = xmlDoc.CreateElement("page");
pageElement.AppendChild(xmlDoc.CreateCDataSection(page));
pagesElement.AppendChild(pageElement);
}
return pagesElement.CreateNavigator().Select(".");
}
</msxml:script>
<xsl:param name="currentPage"/>
<xsl:variable name="content" select="/macro/content" />
<xsl:variable name="pageNumber" select="/macro/pageNumber" />
<xsl:variable name="joinContent">
<xsl:choose>
<xsl:when test="/macro/joinContent = ''">
<xsl:value-of select="boolean(false)" />
</xsl:when>
<xsl:otherwise><xsl:value-of select="/macro/joinContent" /></xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:variable name="splitExpr"><hr class="pagebreak" /></xsl:variable>
<xsl:template match="/">
<xsl:variable name="pages" select="custom:SplitMultiPageText($content, $splitExpr)" />
<xsl:variable name="pageCount" select="count($pages/page)" />
<xsl:choose>
<xsl:when test="$pageCount = 1 or string($joinContent) = 'true'">
<xsl:for-each select="$pages/page">
<xsl:value-of
select="umbraco.library:RenderMacroContent(., $currentPage/@id)"
disable-output-escaping="yes" />
</xsl:for-each>
</xsl:when>
<xsl:otherwise>
<p class="multiPageNotice">This document is split among multiple pages. To view
the other pages, use the <strong>page selector</strong> near the bottom of the screen.</p>
<xsl:for-each select="$pages/page">
<xsl:if test="position() = $pageNumber or ( $pageNumber = '' and position() = 1 )">
<xsl:value-of
select="umbraco.library:RenderMacroContent(., $currentPage/@id)"
disable-output-escaping="yes" />
</xsl:if>
</xsl:for-each>
</xsl:otherwise>
</xsl:choose>
<xsl:if test="$pageCount > 1 and string($joinContent) != 'true'">
<div class="pageSelector">
<p>Page: </p>
<ul>
<xsl:for-each select="$pages/page">
<li>
<xsl:choose>
<xsl:when test="position() = $pageNumber or ( $pageNumber = '' and position() = 1 )">
<xsl:value-of select="position()" />
</xsl:when>
<xsl:otherwise>
<a href="{umbraco.library:NiceUrl($currentPage/@id)}/page/{position()}">
<xsl:value-of select="position()" />
</a>
</xsl:otherwise>
</xsl:choose>
</li>
</xsl:for-each>
</ul>
</div>
</xsl:if>
</xsl:template>
</xsl:stylesheet>
答案 0 :(得分:1)
鉴于您的评论,宏可能会将内容持久保存到独立于应用程序/ umbraco配置的商店,例如:一个xml文件或一个基于数据库的会话。这显然会使应用程序重启之外的数据持续存在。显然,我们必须看到宏的代码。