如何在GitHub页面上启用目录索引

时间:2016-08-19 22:46:18

标签: git github indexing server

我需要在GH页面上显示目录内容。

更喜欢

  1. 自动,无index.html
  2. 用于自动生成index.html的工具或库
  3. 任何其他方法
  4. 所以,如果我的GH页面存储库中有一个FS:

    http://github.com/[username]/[username].github.io/

    script/
    - app/
      - core/
        - init.js
    - lib/
      - Element.animate.js
      - Object.overlay.js
    - mod/
      - anim/
        - global/
          - carousel/
            - carousel.js
          - global.js
    - ext/
      - cfgs.js
    index.html
    

    我希望每个目录网址都像往常一样索引,就像这样。

    http://[username].github.io/script/

    - app/
    - lib/
    - mod/
    - ext/
    

    http://[username].github.io/script/mod/anim/global/

    - carousel/
    - global.js
    

    我唯一能想到的是首选项#2,编写或查找脚本以从GitHub Repo页面或我的FS上的本地Repo自动生成index.html。

4 个答案:

答案 0 :(得分:6)

我也想这样做。我尝试将内容为.htaccess的{​​{1}}文件上传到相关目录,但这不起作用。

所以,我使用你的选项#2,编写一个小的Python脚本来为目录生成一个索引文件文件。

Options +Indexes

答案 1 :(得分:4)

这种方式更好,它将进入子目录并为它们制作索引文件

""" Build index from directory listing

make_index.py </path/to/directory> [--header <header text>]
"""
from __future__ import print_function
import os.path, time

INDEX_TEMPLATE = r"""

<html>
<head>
<title>${header}</title>
<meta name="description" content="${header}"/>

</head>
<body>
    <h2>Index of ${header}</h2>
    <p>
    <table>
        <tbody>
            <tr>
                <th valign="top"><img src="${ROOTDIR}images/blank.gif"
                    alt="[ICO]"></th>
                <th><a href="?C=N;O=D">Name</a></th>
                <th><a href="?C=M;O=A">Last modified</a></th>
                <th><a href="?C=S;O=A">Size</a></th>
                <th><a href="?C=D;O=A">Description</a></th>
            </tr>
            <tr>
                <th colspan="5"><hr></th>
            </tr>
            <tr>
                <td valign="top"><img src=" "
                    alt="[PARENTDIR]"></td>
                <td><a href="../">Parent Directory</a></td>
                <td>&nbsp;</td>
                <td align="right">-</td>
                <td>&nbsp;</td>
            </tr>
            <tr>
                <th colspan="5"><hr></th>
            </tr>

            % for name in dirnames:
            <tr>
                <td valign="top"><img src=" "
                    alt="[DIR]"></td>
                <td><a href="${name}">${name}</a></td>
                <td align="right">${time}</td>
                <td align="right">-</td>
                <td>&nbsp;</td>
            </tr>
            % endfor
            % for name in filenames:
            <tr>
                <td valign="top"><img src=" "
                    alt="[DIR]"></td>
                <td><a href="${name}">${name}</a></td>
                <td align="right">${time}</td>
                <td align="right">-</td>
                <td>&nbsp;</td>
            </tr>
            % endfor
            </p>
        </tbody>
    </table>
</body>
</html>
"""

EXCLUDED = ['index.html']

import os
import argparse

# May need to do "pip install mako"
from mako.template import Template

def fun(dir,rootdir):
    print('Processing: '+dir)
    filenames = [fname for fname in sorted(os.listdir(dir))
              if fname not in EXCLUDED and os.path.isfile(dir+fname)]
    dirnames = [fname for fname in sorted(os.listdir(dir))
            if fname not in EXCLUDED  ]
    dirnames = [fname for fname in dirnames if fname not in filenames]
#    header = os.path.basename(dir)
    f = open(dir+'/index.html','w')
    print(Template(INDEX_TEMPLATE).render(dirnames=dirnames,filenames=filenames, header=dir,ROOTDIR=rootdir,time=time.ctime(os.path.getctime(dir))),file=f)
    f.close()
    for subdir in dirnames:
        try:
            fun(dir+subdir+"/",rootdir+'../')
        except:
            pass

def main():
    parser = argparse.ArgumentParser()
    parser.add_argument("directory")
    parser.add_argument("--header")
    args = parser.parse_args()
    fun(args.directory+'/','../')

if __name__ == '__main__':
    main()

答案 2 :(得分:3)

如果您想要一个不需要任何更新的动态索引,我发现的唯一方法就是使用github contents api在客户端生成它。

这是一个简单的示例,可在项目的顶层目录中创建指向文件的链接。如果要使用此方法支持子目录,则必须递归地请求每个文件夹的内容。

<html>
  <body>
    <script>
      (async () => {
        const response = await fetch('https://api.github.com/repos/:user/:repo/contents/');
        const data = await response.json();
        let htmlString = '<ul>';
        for (let file of data) {
          htmlString += `<li><a href="${file.path}">${file.name}</a></li>`;
        }
        htmlString += '</ul>';
        document.getElementsByTagName('body')[0].innerHTML = htmlString;
      })()
    </script>
  <body>
</html>

Here's an example,在这里我用它来为我拥有的平面仓库创建一个简单的目录。

答案 3 :(得分:0)

我为此写了一个程序。

enter image description here

请参阅apindex