svg mimetype在uliweb中的設置

發現 plugs 中的wiki在python 2.6下以img方式顯示svg不正確,經檢查是content-type不對,正確的應該是 image/svg+xml。可是在2.7下就是正確的。因而發現2.6缺省的mime列表不全。查看了mimetypes模塊源碼,大概是這樣處理的:python

  1. mimetypes會有自動檢查系統中可能存放mimetypes的配置文件,它們能夠放在如: /etc, usr/local/etc 等目錄下,還能夠直接識別象apache的標準安裝目錄下的mime.types文件。不過nginx的mime.types的格式和標準的不一樣,因此還沒法直接識別。
  2. mimetypes模塊已經內置了一些mimetypes的類型,存放在 types_map 變量中。它做爲缺省值。能夠和mimetypes的配置文件合併。而types_map中,在2.7版本下其實也不存在svg的配置。不過在windows下,還能夠從註冊表中獲取。
  3. 新的類型能夠經過 add_type(type, ext) 來註冊。

在個人環境中,python是2.6,nginx中有svg的配置,標準的 /etc/mime.types 下沒有。我使用的是nginx做爲web server提供靜態文件服務。若是隻是使用nginx的靜態文件,其實這個和python無關了,由於能夠不通過python直接提供處理。linux

可是有些下載要通過python的處理,如 uliweb.contrib.upload app提供的文件下載功能。所以仍是須要讓python可以正確識別mimetypes的。一種方式是在某個mime.types中添加新的類型,不過這種試對於新的環境仍然要修改。因而我在upload app中増加了 MIME_TYPES 的配置,如:nginx

[MIME_TYPES]
.svg = 'image/svg+xml'

每種後綴對應一個類型。這樣就能夠將mimetypes配置到應用中了。通用性比較好。git

不過,要注意,它只對應用有效。github

update:web

其實不是由於python版本的問題,而是環境問題。2.6和2.7中的mimetypes中的types_map其實都沒有對svg的類型定義。我之因此出現這樣的問題是2.7是在windows環境下,它能夠從註冊表中讀mimetypes的信息。而2.6是在linux下,的確沒有定義。apache

相關文章
相關標籤/搜索