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.20.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.20-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pywebfs-1.1.20.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.20.tar.gz
Algorithm Hash digest
SHA256 c17154d11a568f3bbb5e774778b303c6ff5fc4b48c10a1f5c01a4d9c2c7adc6f
MD5 7330a2c7e895c19a0910b6c790b9e68d
BLAKE2b-256 3231d9231879f17f71a2f59e896c07caa1d07fe314f74f257ecc59b3fcb3fa55

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pywebfs-1.1.20-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.20-py3-none-any.whl
Algorithm Hash digest
SHA256 440aa78f8349000c564363a21f12f479262555cf48c3547100b181b30b043f44
MD5 836d2135077a30e1066d711ca738daa5
BLAKE2b-256 cddcbbd2fc49c59c0a4e74299ec8361a6703e935f726861aa237a1ec49fb3c14

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