发现 plugs 中的wiki在python 2.6下以img方式显示svg不正确,经检查是content-type不对,正确的应该是 image/svg+xml。但是在2.7下就是正确的。于是发现2.6缺省的mime列表不全。查看了mimetypes模块源码,大概是这样处理的:
- mimetypes会有自动检查系统中可能存放mimetypes的配置文件,它们可以放在如: /etc, usr/local/etc 等目录下,还可以直接识别象apache的标准安装目录下的mime.types文件。不过nginx的mime.types的格式和标准的不同,所以还无法直接识别。
- mimetypes模块已经内置了一些mimetypes的类型,存放在 types_map 变量中。它作为缺省值。可以和mimetypes的配置文件合并。而types_map中,在2.7版本下其实也不存在svg的配置。不过在windows下,还可以从注册表中获取。
- 新的类型可以通过
add_type(type, ext)
来注册。
在我的环境中,python是2.6,nginx中有svg的配置,标准的 /etc/mime.types
下没有。我使用的是nginx作为web server提供静态文件服务。如果只是使用nginx的静态文件,其实这个和python无关了,因为可以不经过python直接提供处理。
但是有些下载要经过python的处理,如 uliweb.contrib.upload
app提供的文件下载功能。因此还是需要让python能够正确识别mimetypes的。一种方式是在某个mime.types中添加新的类型,不过这种试对于新的环境仍然要修改。于是我在upload app中増加了 MIME_TYPES
的配置,如:
[MIME_TYPES]
.svg = 'image/svg+xml'
每种后缀对应一个类型。这样就可以将mimetypes配置到应用中了。通用性比较好。
不过,要注意,它只对应用有效。
update:
其实不是因为python版本的问题,而是环境问题。2.6和2.7中的mimetypes中的types_map其实都没有对svg的类型定义。我之所以出现这样的问题是2.7是在windows环境下,它可以从注册表中读mimetypes的信息。而2.6是在linux下,的确没有定义。