使用 nginx 自定义自动索引页面

pvo*_*orb 6 nginx

有没有办法在 nginx 中定义自己的自动索引页面?

我想将我自己的 HTML 和 CSS 添加到生成的自动索引页面。

小智 8

使用 XSLT 可以使用xslt 模块自定义 autoindex 的 xml 输出:

location / {
    autoindex on;
    autoindex_format xml;
    xslt_stylesheet /path/to/custom.xslt
}
Run Code Online (Sandbox Code Playgroud)

这就是我在这个项目中所做的ngx-superbindex


sim*_*lev 7

gibatronic相同的答案:利用 xslt 的力量!看看这个示例 xslt 文件:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:template match="/">
    <html>
    <body>
        <h3>Dafshabbat</h3>
        <table border="0">
        <tr bgcolor="#9acd32">
            <th>name</th>
            <th>size</th>
            <th>date</th>
        </tr>
        <xsl:for-each select="list/*">
        <xsl:sort select="@mtime"/>

            <xsl:variable name="name">
                <xsl:value-of select="."/>
            </xsl:variable>
            <xsl:variable name="size">
                <xsl:if test="string-length(@size) &gt; 0">
                        <xsl:if test="number(@size) &gt; 0">
                            <xsl:choose>
                                    <xsl:when test="round(@size div 1024) &lt; 1"><xsl:value-of select="@size" /></xsl:when>
                                    <xsl:when test="round(@size div 1048576) &lt; 1"><xsl:value-of select="format-number((@size div 1024), '0.0')" />K</xsl:when>
                                    <xsl:otherwise><xsl:value-of select="format-number((@size div 1048576), '0.00')" />M</xsl:otherwise>
                            </xsl:choose>
                        </xsl:if>
                </xsl:if>
            </xsl:variable>
            <xsl:variable name="date">
                <xsl:value-of select="substring(@mtime,9,2)"/>-<xsl:value-of select="substring(@mtime,6,2)"/>-<xsl:value-of select="substring(@mtime,1,4)"/><xsl:text> </xsl:text>
                <xsl:value-of select="substring(@mtime,12,2)"/>:<xsl:value-of select="substring(@mtime,15,2)"/>:<xsl:value-of select="substring(@mtime,18,2)"/>
            </xsl:variable>

        <tr>
            <td><a href="{$name}"><xsl:value-of select="."/></a></td>
            <td align="right"><xsl:value-of select="$size"/></td>
            <td><xsl:value-of select="$date"/></td>
        </tr>

        </xsl:for-each>
        </table>
    </body>
    </html>
    </xsl:template>
</xsl:stylesheet>
Run Code Online (Sandbox Code Playgroud)

我特别喜欢的是按日期排序的能力,这里定义为: <xsl:sort select="@mtime"/>

与在 .htaccess 文件中添加几个指令相比,它当然需要更多的努力来设置。并且,xml文件读写起来很麻烦。但是,定制潜力很大,非常好!

请参阅w3schools的介绍性教程。


MCO*_*MCO 7

事实证明,您可以使用http 添加模块添加有效的 html 。

我并不声称完全理解它,但是有一个存储库可以完全满足您的要求,因此您可以尝试从那里开始。

编辑(2019):

仔细研究了一下,这其实是一个相当简单的任务。

  • 创建一个隐藏文件夹,例如.assets,这样 autoindex 就不会显示它。
  • 在其中创建一个 html 文件,其中包含要附加到网页的任何内容。
  • 然后只需添加add_after_body /.assets/my_html_file.html到您的 nginx 规则即可。哒哒!

请注意,根据文档,该模块不是默认编译的一部分。我发现ubuntu上的nginx包有它。