diff options
author | Kristján Valur Jónsson <kristjan@ccpgames.com> | 2009-06-28 21:04:17 +0000 |
---|---|---|
committer | Kristján Valur Jónsson <kristjan@ccpgames.com> | 2009-06-28 21:04:17 +0000 |
commit | b47691d927c5e410018ee1bf12df6294f7f666ee (patch) | |
tree | a39fb6b5ba30a9d846a10da79489b62b1609369e /Lib/BaseHTTPServer.py | |
parent | 74182d96241ee98c88edddb223fca0247f0a9162 (diff) | |
download | cpython-b47691d927c5e410018ee1bf12df6294f7f666ee.tar.gz |
http://bugs.python.org/issue6267
Cumulative patch to http and xmlrpc
Diffstat (limited to 'Lib/BaseHTTPServer.py')
-rw-r--r-- | Lib/BaseHTTPServer.py | 28 |
1 files changed, 18 insertions, 10 deletions
diff --git a/Lib/BaseHTTPServer.py b/Lib/BaseHTTPServer.py index acd839410e..9bb3ba4faf 100644 --- a/Lib/BaseHTTPServer.py +++ b/Lib/BaseHTTPServer.py @@ -309,18 +309,26 @@ class BaseHTTPRequestHandler(SocketServer.StreamRequestHandler): commands such as GET and POST. """ - self.raw_requestline = self.rfile.readline() - if not self.raw_requestline: + try: + self.raw_requestline = self.rfile.readline() + if not self.raw_requestline: + self.close_connection = 1 + return + if not self.parse_request(): + # An error code has been sent, just exit + return + mname = 'do_' + self.command + if not hasattr(self, mname): + self.send_error(501, "Unsupported method (%r)" % self.command) + return + method = getattr(self, mname) + method() + self.wfile.flush() #actually send the response if not already done. + except socket.timeout, e: + #a read or a write timed out. Discard this connection + self.log_error("Request timed out: %r", e) self.close_connection = 1 return - if not self.parse_request(): # An error code has been sent, just exit - return - mname = 'do_' + self.command - if not hasattr(self, mname): - self.send_error(501, "Unsupported method (%r)" % self.command) - return - method = getattr(self, mname) - method() def handle(self): """Handle multiple requests if necessary.""" |