質問

次のようにRailsアプリケーションでPaperClipプラグインを使用しています:

  has_attached_file :photo, :styles => {:small => '64X64>', :medium => '250X250>'},
                                      :url  => "/assets/user_photos/:id/:style/:basename.:extension",
                                      :path => ":rails_root/public/assets/user_photos/:id/:style/:basename.:extension"
#  validates_attachment_presence :photo
  validates_attachment_content_type :photo, :content_type => ['image/jpeg', 'image/png','image/gif']
  validates_attachment_size :photo, :less_than => 1.megabytes

開発(Mac OSX + Mongrel)では正常に動作します。しかし、本番環境(Linux Debian + Apache / Passenger)に配置すると、.gifのみが受け入れられ、.pngおよび.jpgに対して次のエラーが表示されます。

 Photo /tmp/stream20091028-20066-1t1a0oz-0 is not recognized by the 'identify' command.
 Photo /tmp/stream20091028-20066-1t1a0oz-0 is not recognized by the 'identify' command.

いくつかのチュートリアルが示唆するように、次の行を追加しようとしましたが、助けにはなりませんでした!

Paperclip.options[:command_path] = "/usr/local/bin"
役に立ちましたか?

解決

実動サーバーで、実行してみてください:

which identify

これにより、ImageMagickの識別バイナリへのパスが提供されます-ImageMagickがインストールされていない場合、またはパスにない場合。

" / usr / bin / identify"のようなものが返される場合、production.rb環境ファイルのPaperclipオプションを次のように設定します。

Paperclip.options[:command_path] = "/usr/bin"

他のヒント

他の誰かがこの問題に遭遇した場合、JPGファイルを処理するときにMac OSX Snow Leopardで同じエラーが発生しました(GIFファイルは問題なく動作しました)。 Rails 3.0.5とPaperclip 2.3.11。を実行しています。

[paperclip] An error was received while processing: #<Paperclip::NotIdentifiedByImageMagickError: /var/folders/9D/9DvX1hqSFr04U3drvD9o0U+++TI/-Tmp-/stream20110420-50661-l9je0z.jpg is not recognized by the 'identify' command.

httpにあるjpegエンコーディングライブラリをソースからインストールすることで問題を修正しました。 //www.ijg.org/files/jpegsrc.v8c.tar.gz

cd /usr/local/src
tar xvfz jpeg-8c.tar.gz
cd jpeg-8c
export MACOSX_DEPLOYMENT_TARGET=10.6
./configure --enable-shared --prefix=$CONFIGURE_PREFIX
make
sudo make install

その後、ImageMagickをソースから再インストールしました:

cd /usr/local/src
tar xvfz ImageMagick-6.6.9-5.tar.gz
cd ImageMagick-6.6.9-5
export CPPFLAGS=-I/usr/local/include
export LDFLAGS=-L/usr/local/lib
./configure --prefix=/usr/local --disable-static --with-modules --without-perl --without-magick-plus-plus --with-quantum-depth=8 --disable-openmp
make
sudo make install

その後、PaperclipでJPGファイルを正常にアップロードできました。

[paperclip] convert '/var/folders/9D/9DvX1hqSFr04U3drvD9o0U+++TI/-Tmp-/stream20110420-86578-3ntsgn.jpg[0]' -resize "100x100>" '/var/folders/9D/9DvX1hqSFr04U3drvD9o0U+++TI/-Tmp-/stream20110420-86578-3ntsgn20110420-86578-iiszw5' 2>/dev/null
...
[paperclip] saving /Users/xxx/myrailsapp/public/system/images/5/original/IMG_0001.jpg

Lionにアップグレードした後も同じ問題が発生しました。 'identify image.jpg'を実行すると、 dyld:Library not loaded エラーがスローされました。

この投稿は問題の解決に役立ちました。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top