summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStéphane Wirtel <stephane@wirtel.be>2019-03-25 23:52:56 +0100
committerBrett Cannon <brettcannon@users.noreply.github.com>2019-03-25 15:52:56 -0700
commit360e1e4c519cfc139de707bcdd1e6c871eec79ee (patch)
tree65196415f6239702838a7a41292a1a1b82c92bcb
parent1075d1684ab84dc7c28d93cfb46e95e70d3b6d3b (diff)
downloadcpython-git-360e1e4c519cfc139de707bcdd1e6c871eec79ee.tar.gz
bpo-36345: Add a new example in the documentation of wsgiref (#12511)
-rw-r--r--Doc/library/wsgiref.rst32
-rw-r--r--Misc/NEWS.d/next/Documentation/2019-03-23-09-25-12.bpo-36345.L704Zv.rst2
2 files changed, 34 insertions, 0 deletions
diff --git a/Doc/library/wsgiref.rst b/Doc/library/wsgiref.rst
index ffca1fc816..b85ec53c8a 100644
--- a/Doc/library/wsgiref.rst
+++ b/Doc/library/wsgiref.rst
@@ -781,3 +781,35 @@ This is a working "Hello World" WSGI application::
# Serve until process is killed
httpd.serve_forever()
+
+
+Example of a small wsgiref-based web server::
+
+ # Takes a path to serve from and an optional port number (defaults to 8000),
+ # then tries to serve files. Mime types are guessed from the file names, 404
+ # errors are raised if the file is not found.
+ import sys
+ import os
+ import mimetypes
+ from wsgiref import simple_server, util
+
+ def app(environ, respond):
+ fn = os.path.join(path, environ['PATH_INFO'][1:])
+ if '.' not in fn.split(os.path.sep)[-1]:
+ fn = os.path.join(fn, 'index.html')
+ type = mimetypes.guess_type(fn)[0]
+
+ if os.path.exists(fn):
+ respond('200 OK', [('Content-Type', type)])
+ return util.FileWrapper(open(fn, "rb"))
+ else:
+ respond('404 Not Found', [('Content-Type', 'text/plain')])
+ return [b'not found']
+
+ path = sys.argv[1]
+ port = int(sys.argv[2]) if len(sys.argv) > 2 else 8000
+ with simple_server.make_server('', port, app) as httpd:
+ print("Serving {} on port {}, control-C to stop".format(path, port))
+
+ # Serve until process is killed
+ httpd.serve_forever()
diff --git a/Misc/NEWS.d/next/Documentation/2019-03-23-09-25-12.bpo-36345.L704Zv.rst b/Misc/NEWS.d/next/Documentation/2019-03-23-09-25-12.bpo-36345.L704Zv.rst
new file mode 100644
index 0000000000..c6206a74ab
--- /dev/null
+++ b/Misc/NEWS.d/next/Documentation/2019-03-23-09-25-12.bpo-36345.L704Zv.rst
@@ -0,0 +1,2 @@
+Using the code of the ``Tools/scripts/serve.py`` script as an example in the
+:mod:`wsgiref` documentation. Contributed by Stéphane Wirtel.