From: Guido van Rossum Date: Thu, 23 Aug 2001 13:38:15 +0000 (+0000) Subject: SF patch #454553 by Walter Dörwald: auto-guess content-type header for X-Git-Tag: v2.2a3~372 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=88e0b5bee0e69b628a9358c987bf49ac885d1c21;p=python SF patch #454553 by Walter Dörwald: auto-guess content-type header for ftp urls. --- diff --git a/Doc/lib/liburllib.tex b/Doc/lib/liburllib.tex index 6522cf7b87..fb9524acec 100644 --- a/Doc/lib/liburllib.tex +++ b/Doc/lib/liburllib.tex @@ -43,7 +43,8 @@ returned by the server at the head of the retrieved HTML page (including Content-Length and Content-Type). When the method is FTP, a Content-Length header will be present if (as is now usual) the server passed back a file length in response to the FTP retrieval -request. When the method is local-file, returned headers will include +request. A Content-Type header will be present if the MIME type can +be guessed. When the method is local-file, returned headers will include a Date representing the file's last-modified time, a Content-Length giving file size, and a Content-Type containing a guess at the file's type. See also the description of the diff --git a/Lib/urllib.py b/Lib/urllib.py index f60a84154a..a255956efd 100644 --- a/Lib/urllib.py +++ b/Lib/urllib.py @@ -440,6 +440,7 @@ class URLopener: def open_ftp(self, url): """Use FTP protocol.""" + import mimetypes, mimetools, StringIO host, path = splithost(url) if not host: raise IOError, ('ftp error', 'no host given') host, port = splitport(host) @@ -482,12 +483,13 @@ class URLopener: value in ('a', 'A', 'i', 'I', 'd', 'D'): type = value.upper() (fp, retrlen) = self.ftpcache[key].retrfile(file, type) + mtype = mimetypes.guess_type("ftp:" + url)[0] + headers = "" + if mtype: + headers += "Content-Type: %s\n" % mtype if retrlen is not None and retrlen >= 0: - import mimetools, StringIO - headers = mimetools.Message(StringIO.StringIO( - 'Content-Length: %d\n' % retrlen)) - else: - headers = noheaders() + headers += "Content-Length: %d\n" % retrlen + headers = mimetools.Message(StringIO.StringIO(headers)) return addinfourl(fp, headers, "ftp:" + url) except ftperrors(), msg: raise IOError, ('ftp error', msg), sys.exc_info()[2]