By default, carrierwave uses the uploaded file's extension to guess the content type. Sometimes you'd prefer to actually look at the file and set the content type based on that, so users can't upload php files as i_am_lying.jpg and have the server try to process them as images.
This gem checks the file when it's first uploaded, sets the content type as appropriate and, if the filename's original extension doesn't match the content type, renames it so it does.
Add this line to your application's Gemfile:
gem 'carrierwave-mimetype-magic'
And then execute:
$ bundle install
Or install it yourself as:
$ gem install carrierwave-mimetype-magic
Just include the module in your uploader:
class ImageUploader < CarrierWave::Uploader::Base
include CarrierWave::MimetypeMagic
end
And now uploaded files' content_type will be set appropriately, and uploads will automatically be renamed before being passed on to the processors. Given a jpeg file named test_1.pdf, the file will be renamed test_1.jpg before being passed off to normal carrierwave processing.
Originally based on the carrierwave-mymetype-fu (that based on carrierwave-magic) gem, but using mimemagic rather than MimetypeFu, that works incorrect with MS files.
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request