http-server
is a static file server with zero dependencies: just one binary to run. It also supports:
- CORS support: by setting the
Access-Control-Allow-Origin
header to*
.HEAD
requests, although unnecessary when doing CORS onGET
requests, are also supported. - Authentication support: via either plain username and password or through a JWT token, with optional support for validating if the token isn't expired.
- Directory listing: if no
index.html
orindex.htm
files are present in the directory, a directory listing page will show instead. - Markdown support: if a
README.md
orreadme.md
file is present in the directory during directory listing, it will be rendered as HTML. Additional support for GitHub-flavored markdown is also available. - Fully air-gapped: the directory listing feature is fully air-gapped, meaning that it does not require any external resources to be loaded. This is useful for environments where internet access is not available.
- Redirections support: if a
_redirections
file exists in the target directory, it will be used to redirect requests to other locations. Learn about the syntax in the docs.
The app is available both as a standalone binary and as a Docker container image.
For an example site built with http-server
, check the demo page: https://patrickdappollonio.github.io/http-server-testing-page/
. The repository for the demo page contains the folder being served.
Find the latest version available here. latest
will always map to the latest version, which could led you to download a newer major version that might contain a breaking change. I recommend using v2
for the tag, since it will always map to a stable version with all potential patches applied. This is the safest way to use to avoid any breaking changes.
# stable version 2
docker pull ghcr.io/patrickdappollonio/docker-http-server:v2
# pin to specific version
docker pull ghcr.io/patrickdappollonio/docker-http-server:v2.0.0
# bleeding edge version (will always update to latest)
docker pull ghcr.io/patrickdappollonio/docker-http-server:latest
There are three ways to configure the container:
- Using a YAML configuration file: create a configuration file named
.http-server.yaml
. This file cannot be accessed using the file explorer mode nor it will show up in the directory listing. The variable names match the command line flags. For example, to set--disable-markdown
, you can usedisable-markdown: true
in the configuration file. - Using environment variables: The environment variables match the command line flags. For example, to set
--disable-markdown
, you can useDISABLE_MARKDOWN=true
as an environment variable. Additionally, and to avoid collisions, all environment variables can be prefixed withFILE_SERVER_
. For example, to set--path
parameter, which would collide with your Operating System's$PATH
, you can use insteadFILE_SERVER_PATH
. - Overwriting the
command
andargs
: Overriding the arguments passed to the container is also possible. For Docker, see overridingCMD
but keep theENTRYPOINT
intact. Fordocker compose
, see overriding thecommand
. For Kubernetes, see overridingcommand
andargs
.
You can download the latest version from the Releases page.
You can also install the app using Homebrew. A Homebrew tap is available with the latest version:
brew install patrickdappollonio/tap/http-server
The following options are available.
A simple HTTP server and a directory listing tool.
Usage:
http-server [flags]
Flags:
--banner string markdown text to be rendered at the top of the directory listing page
--cors enable CORS support by setting the "Access-Control-Allow-Origin" header to "*"
--custom-404 string custom "page not found" to serve
--custom-404-code int custtom status code for pages not found
--disable-cache-buster disable the cache buster for assets from the directory listing feature
--disable-directory-listing disable the directory listing feature and return 404s for directories without index
--disable-etag disable etag header generation
--disable-markdown disable the markdown rendering feature
--disable-redirects disable redirection file handling
--ensure-unexpired-jwt enable time validation for JWT claims "exp" and "nbf"
--etag-max-size string maximum size for etag header generation, where bigger size = more memory usage (default "5M")
--gzip enable gzip compression for supported content-types
-h, --help help for http-server
--hide-links hide the links to this project's source code visible in the header and footer
--jwt-key string signing key for JWT authentication
--markdown-before-dir render markdown content before the directory listing
--password string password for basic authentication
-d, --path string path to the directory you want to serve (default "./")
--pathprefix string path prefix for the URL where the server will listen on (default "/")
-p, --port int port to configure the server to listen on (default 5000)
--title string title of the directory listing page
--username string username for basic authentication
-v, --version version for http-server
All the available configuration options are documented in the docs. You can find them here.