Browse files

mytornado.StaticFileHandler: 下载文件的支持

  • Loading branch information...
1 parent 37acf1a commit 235c1cffab1cd310372df94297b93716ed4e7842 @lilydjwg committed Mar 31, 2012
Showing with 14 additions and 4 deletions.
  1. +14 −4 pylib/
@@ -131,12 +131,14 @@ def get(self, path, include_body=True):
raise HTTPError(403, "%s is not in root static directory", path)
self.send_file(abspath, include_body)
- def send_file(self, abspath, include_body=True, path=None):
+ def send_file(self, abspath, include_body=True, path=None, download=False):
send a static file to client
``abspath``: the absolute path of the file on disk
``path``: the path to use as if requested, if given
+ ``download``: whether we should try to persuade the client to download the
+ file. This can be either ``True`` or the intended filename
If you use ``send_file`` directly and want to use another file as default
index, you should set this parameter.
@@ -180,10 +182,17 @@ def send_file(self, abspath, include_body=True, path=None):
if not os.path.isfile(abspath):
raise HTTPError(403, "%s is not a file" % self.request.path)
- self._send_file_async(path, abspath, include_body)
+ if download is not False:
+ if download is True:
+ filename = os.path.split(path)[1]
+ else:
+ filename = download
+ self.set_header('Content-Disposition', 'attachment; filename='+filename)
+ self._send_file_async(path, abspath, include_body, notype=download is not False)
- def _send_file_async(self, path, abspath, include_body=True):
+ def _send_file_async(self, path, abspath, include_body=True, notype=False):
stat_result = os.stat(abspath)
modified = datetime.datetime.fromtimestamp(stat_result[stat.ST_MTIME])
self.set_header("Last-Modified", modified)
@@ -193,7 +202,8 @@ def _send_file_async(self, path, abspath, include_body=True):
if not mime_type:
# default is plain text
mime_type = 'text/plain'
- self.set_header("Content-Type", mime_type)
+ if not notype:
+ self.set_header("Content-Type", mime_type)
# make use of gzip when possible
if self.settings.get("gzip") and \

0 comments on commit 235c1cf

Please sign in to comment.