Rails 3 CSV和XLS导出不提供文件扩展名

And*_*tad 2 csv xls ruby-on-rails

我的用户可以生成一些数据的报告,并决定他们想要的格式.

他们可以选择HTML,CSV或XLS

这是表单(省略了数据,这只是格式选择器)

<%= form_tag "/report", :method => :get %>
    Format <select id='format' name='format'>
                <option value='html' selected='selected'>View in browser (HTML)</option>
                <option value='csv'>Export to CSV file</option>
                <option value='xls'>Export to exel (XLS)</option>
            </select>

<%= submit_tag "Make report", :class => 'submit' %>
Run Code Online (Sandbox Code Playgroud)

此表单适用于此操作

def report
    #...Again omitting data stuff
    respond_to do |format|
      format.html
      format.csv 
      format.xls 
    end
  end
Run Code Online (Sandbox Code Playgroud)

我有相应的视图文件.

喜欢 report.xls.erb

在我的日志中,我得到了

Processing by ..Controller#report as XLS
Run Code Online (Sandbox Code Playgroud)

但是,浏览器无需扩展即可下载文件.

如果我将form_tag行更改为此.

<%= form_tag "/report.xls", :method => :get %>
Run Code Online (Sandbox Code Playgroud)

该文件获得.xls扩展名.

我已经设置了xls mime_types

如何在表单中设置格式?

Mon*_*tas 6

这是来自不同的问题.

您可以设置标题以告知文件的浏览器名称.

format.xls do
  response.headers['Content-Disposition'] = 'attachment; filename="' + filename + '.xls"'
  render "report.xls.erb"
end
Run Code Online (Sandbox Code Playgroud)