Я не могу заставить send_file (Model.attachment.path) работать.
Он не дает сбоя, вместо этого он отправляет клиенту файл размером 0 байт, хотя имена файлов правильные.
Эта проблема начала возникать после большого перехода с Rails 2.3.8 на 3.
В ходе этой миграции произошло много других вещей, и я постараюсь описать их все.
- Смена дистрибуции / Смена сервера. Rackspace RHEL5 для Linode Ubuntu 10.04LTS
- Изменение версии Ruby, 1.8.6 -> 1.9.2
- Изменение версии Rails, 2.3.8 -> 3.0.0
- Смена платформы httpd, apache2 -> nginx (Тем не менее, я попробовал и на apache2, но это не сработало).
Я переместил вложения через ftp, так как они не были частью моего git-репозитория, поэтому они были опубликованы через cap deploy, вместо этого вручную ftp remote (RHEL5) на локальный (Win7), затем локальный (Win7) на удаленный (Ubuntu10).
Я знаю, что FTP не сохраняет права доступа к файлам при передаче, поэтому я также сделал имитацию chmod, которые были на моих предыдущих серверах, поэтому они почти идентичны. (пользователи / группы различны, для пользователя установлено значение root: root вместо olduser: olduser).
Фрагмент запроса на скачивание вложения из моего производственного журнала.
Started GET "/attachments/replies/1410?1277105698" for 218.102.140.205 at 2010-09-16 09:44:31 +0000
Processing by AttachmentsController#replies as HTML
Parameters: {"1277105698"=>nil, "id"=>"1410"}
Sent file /srv/app/releases/20100916094249/attachments/replies/UE0003-Requisition_For_Compensation_Leave.doc (0.2ms)
Completed 200 OK in 78ms
Все хорошо. Позвольте мне также исключить локальные проблемы, я пытался загрузить через Chrome на Win7 и Ubuntu (на Vbox).
Позвольте мне также заверить вас, что путь действительно правильный.
root@li162-41:/srv/app/current# tail /srv/app/releases/20100916094249/attachments/replies/UE0003-Requisition_For_Compensation_Leave.doc
#
#
%17nw
HQ��+1ae����
%33333333333(��QR���HX�"%%��@9
��@�p4��#P@��Unknown������������G��z �Times New Roman5��Symbol3&�
�z �Arial5&�
Итак, чтобы подвести итог вопроса, как получить send_file для фактической отправки файлов вместо поддельного 0-байтового мусора.