Python's http.server extended to include a file upload page
Project description
uploadserver
Python's http.server extended to include a file upload page
Installation
python3 -m pip install --user uploadserver
Usage
python3 -m uploadserver
Accepts the same options as http.server, plus a couple extras (documented below).
After the server starts, the upload page is at /upload. For example, if the server is running at http://localhost:8000/ go to http://localhost:8000/upload .
Warning: This is an upload server, and running it will allow uploads. Uploaded files will replace existing files with the same name.
Now supports uploading multiple files at once! Select multiple files in the web page's file selector, or upload with cURL:
curl http://127.0.0.1:8000/upload -F files=@multiple-example-1.txt -F files=@multiple-example-2.txt
Token Option
Run with a simple token.
python3 -m uploadserver -t helloworld
Now you can upload a file with the token. For example:
curl http://127.0.0.1:8000/upload -F "files=@token-example.txt" -F 'token=helloworld'
Uploads without the token will be rejected. Tokens can be stolen if sent in plain HTTP, so this option is best used with HTTPS.
HTTPS Option
Run with HTTPS:
# Generate self-signed certificate
openssl req -x509 -out localhost.pem -keyout localhost.pem -newkey rsa:2048 -nodes -sha256 -subj '/CN=localhost'
# The server root should not contain the certificate, for security reasons
cd server-root
python3 -m uploadserver -c localhost.pem
Note: This uses a self-signed certificate which clients such as web browser and cURL will warn about. Most browsers will allow you to proceed after adding an exception, and cURL will work if given the -k option. Using your own certificate from a certificate authority will avoid these warnings.
Breaking Changes in 1.0.0
- File field in upload form renamed from
file_1
tofiles
, to reflect support for multiple file upload. Scripts using cURL will need to be upadted with the new field name. - Successful uploads now respond with 204 No Content instead of 200 OK, so that cURL will not default to printing the upload page at the terminal.
Credits
Most of uploadserver/__main__.py
was copied from Python's http.server
.
Thanks to lishoujun for sending the first pull request! (Added the token option.)
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
Built Distribution
Hashes for uploadserver-1.0.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 80a87b8ac75d37a9622ff8b54b48f62a2dad0d19b8a07bdf0dae04c6cbf7d79c |
|
MD5 | 1cd1ab8712583fe02e843b7d709d8d9a |
|
BLAKE2b-256 | ca887cf3958944cfdfe01d593cad635675d9af7979ec332d0d2309b0269b8ab4 |