summaryrefslogtreecommitdiffstats
path: root/Doc/library
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2011-01-02 22:39:10 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2011-01-02 22:39:10 (GMT)
commit9e7d6e598c4eebf6f6726057f5a819518e17f1b6 (patch)
tree5948dc3af5e59701466fffb3cf628b1097e58d80 /Doc/library
parentcb40277ea4be700f3a8e2bc163dc263815a28810 (diff)
downloadcpython-9e7d6e598c4eebf6f6726057f5a819518e17f1b6.zip
cpython-9e7d6e598c4eebf6f6726057f5a819518e17f1b6.tar.gz
cpython-9e7d6e598c4eebf6f6726057f5a819518e17f1b6.tar.bz2
Merged revisions 87653-87655 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r87653 | antoine.pitrou | 2011-01-02 23:06:53 +0100 (dim., 02 janv. 2011) | 3 lines Clarify behaviour of close() and shutdown() on sockets. ........ r87654 | antoine.pitrou | 2011-01-02 23:09:27 +0100 (dim., 02 janv. 2011) | 3 lines Add a shutdown() call in the server example. ........ r87655 | antoine.pitrou | 2011-01-02 23:12:22 +0100 (dim., 02 janv. 2011) | 3 lines Some nits. ........
Diffstat (limited to 'Doc/library')
-rw-r--r--Doc/library/socket.rst9
-rw-r--r--Doc/library/ssl.rst25
2 files changed, 23 insertions, 11 deletions
diff --git a/Doc/library/socket.rst b/Doc/library/socket.rst
index 0af8db6..bad4417 100644
--- a/Doc/library/socket.rst
+++ b/Doc/library/socket.rst
@@ -515,6 +515,9 @@ The module :mod:`socket` exports the following constants and functions:
Module :mod:`SocketServer`
Classes that simplify writing network servers.
+ Module :mod:`ssl`
+ A TLS/SSL wrapper for socket objects.
+
.. _socket-objects:
@@ -551,6 +554,12 @@ correspond to Unix system calls applicable to sockets.
remote end will receive no more data (after queued data is flushed). Sockets are
automatically closed when they are garbage-collected.
+ .. note::
+ :meth:`close()` releases the resource associated with a connection but
+ does not necessarily close the connection immediately. If you want
+ to close the connection in a timely fashion, call :meth:`shutdown()`
+ before :meth:`close()`.
+
.. method:: socket.connect(address)
diff --git a/Doc/library/ssl.rst b/Doc/library/ssl.rst
index e802381..e694928 100644
--- a/Doc/library/ssl.rst
+++ b/Doc/library/ssl.rst
@@ -1,8 +1,8 @@
-:mod:`ssl` --- SSL wrapper for socket objects
-=============================================
+:mod:`ssl` --- TLS/SSL wrapper for socket objects
+=================================================
.. module:: ssl
- :synopsis: SSL wrapper for socket objects
+ :synopsis: TLS/SSL wrapper for socket objects
.. moduleauthor:: Bill Janssen <bill.janssen@gmail.com>
@@ -582,13 +582,17 @@ the other end, and use :func:`wrap_socket` to create a server-side SSL context
for it::
while True:
- newsocket, fromaddr = bindsocket.accept()
- connstream = ssl.wrap_socket(newsocket,
- server_side=True,
- certfile="mycertfile",
- keyfile="mykeyfile",
- ssl_version=ssl.PROTOCOL_TLSv1)
- deal_with_client(connstream)
+ newsocket, fromaddr = bindsocket.accept()
+ connstream = ssl.wrap_socket(newsocket,
+ server_side=True,
+ certfile="mycertfile",
+ keyfile="mykeyfile",
+ ssl_version=ssl.PROTOCOL_TLSv1)
+ try:
+ deal_with_client(connstream)
+ finally:
+ connstream.shutdown(socket.SHUT_RDWR)
+ connstream.close()
Then you'd read data from the ``connstream`` and do something with it till you
are finished with the client (or the client is finished with you)::
@@ -604,7 +608,6 @@ are finished with the client (or the client is finished with you)::
break
data = connstream.read()
# finished with client
- connstream.close()
And go back to listening for new client connections.