Skip to main content

Simple Python HTTP File Server

Project description

Joknarf Tools Pypi version example Licence Python versions

pywebfs

Simple Python HTTP(S) File Server

Install

$ pip install pywebfs

Quick start

  • start http server sharing current directory listening on 0.0.0.0 port 8080
$ pywebfs
  • Browse/Download/Search files using browser http://<yourserver>:8080 image

  • search text in files (like grep -ri) image

features

  • Serve static files
  • Download folder as zip file
  • Quick filter files
  • Keyboard navigation using arrows
  • Search files by name recursively with multiple word any order
  • Search text in files recursively (disable feature with --nosearch)
  • Basic Auth support (single user)
  • Safe url token Auth
  • HTTPS support
  • HTTPS self-signed certificate generator
  • Display owner/group/permissions (POSIX) (disable feature with --noperm)
  • Can be started as a daemon (POSIX)

Customize server

$ pywebfs --dir /mydir --title "my fileserver" --listen 0.0.0.0 --port 8080
$ pywebfs -d /mydir -t "my fileserver" -l 0.0.0.0 -p 8080

Basic auth user/password

$ pywebfs --dir /mydir --user myuser [--password mypass]
$ pywebfs -d /mydir -u myuser [-P mypass]

Generated password is given if no --pasword option

Safe url token auth

$ pywebfs --dir /mydir --tokenurl
$ pywebfs --d /mydir --T

A Token is generated, unless PYWEBFS_TOKEN environment variable is set

HTTPS server

  • Generate auto-signed certificate and start https server
$ pywebfs --dir /mydir --gencert
$ pywebfs -d /mydir --g
  • Start https server using existing certificate
$ pywebfs --dir /mydir --cert /pathto/host.cert --key /pathto/host.key
$ pywebfs -d /mydir -c /pathto/host.cert -k /pathto/host.key

Launch server as a daemon (Linux)

$ pywebfs start
$ pywebfs status
$ pywebfs stop
  • log of server are stored in ~/.pywebfs/pwfs_<listen>:<port>.log

Disclaimer

As built on python http.server, read in the python3 documentation:

Warning http.server is not recommended for production. It only implements basic security checks.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pywebfs-1.1.23.tar.gz (26.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pywebfs-1.1.23-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file pywebfs-1.1.23.tar.gz.

File metadata

  • Download URL: pywebfs-1.1.23.tar.gz
  • Upload date:
  • Size: 26.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for pywebfs-1.1.23.tar.gz
Algorithm Hash digest
SHA256 9e368a314fb3e9309338bdb00be5c06b1d0a0cae6d046c3fbc746bb4762430f8
MD5 57cc019a22ad33ac3e9fea10f86f7b9f
BLAKE2b-256 eb0d68389c37166c4cb529dafb76756bd7a4ccaade364dfb2711a2276d24459c

See more details on using hashes here.

File details

Details for the file pywebfs-1.1.23-py3-none-any.whl.

File metadata

  • Download URL: pywebfs-1.1.23-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for pywebfs-1.1.23-py3-none-any.whl
Algorithm Hash digest
SHA256 1d47c8c6dcb6c9777fc09e95c25f3aaa8fd85993d5c8d818912ea6fa5581f86f
MD5 b7f908b104818054363cf835226631a7
BLAKE2b-256 3db7d904b53f6b7fa7b8411008b5fe61e02981c0bb0200df25c50a290cecf526

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page