在ruby 2 和rails 4 里面使用send_file 下载文件的时候。在IE下面中文名出现乱码的处理方式

在rails中用send_file 进行文件下载。如果文件是中文名,则在IE下面会出现保存文件对话框中文件名是乱码的情况。处理方法如下:

user_agent = request.user_agent.downcase         @escaped_file_name = user_agent.include?("msie") ? CGI::escape(@file_name) : @file_name 
send_file Rails.root.join(@download_match_file_path, @file_name), :type=>"application/octet-stream;charset=utf-8",  :filename => @escaped_file_name , :x_sendfile=>true

处理思路是:
通过获得user_agent 来获取当前用户的浏览器信息
如果是IE,在通过CGI.escape方法对文件名进行转码。
通过send_file 方法下载文件的时候:

  1. 第一个参数是服务器上存放的文件名,应该是未转码前的文件名
  2. 第二个参数是设置下载的文件类型,加入chartset=”utf-8”。
  3. 第三个参数是浏览器提示的保存到本地的文件名,这个文件名在ie下就是经过CGI转码的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用HTML Form以及Rails的form_for和form_tag可以方便地创建表单,其中包括多选下拉框。下面是一些使用技巧: 1. 使用form_for创建表单: ``` <%= form_for @model do |f| %> <%= f.select :attribute, options_for_select([["Option 1", 1], ["Option 2", 2], ["Option 3", 3]], @model.attribute), {}, multiple: true %> <%= f.submit "Submit" %> <% end %> ``` 其中,options_for_select可以为选项提供一个数组,第一个元素是选项的标签,第二个元素是选项的值。在这个例子中,我们创建了一个多选下拉框,它会将选中的值存储在@model.attribute中。 2. 使用form_tag创建表单: ``` <%= form_tag some_path do %> <%= select_tag :attribute, options_for_select([["Option 1", 1], ["Option 2", 2], ["Option 3", 3]], params[:attribute]), {}, multiple: true %> <%= submit_tag "Submit" %> <% end %> ``` 这个例子中,我们使用form_tag创建表单,并创建了一个多选下拉框,它会将选中的值存储在params[:attribute]中。 3. 使用select2插件: select2是一个快速创建具有搜索功能的下拉框的jQuery插件。要使用它,首先需要将它添加到项目中: ``` # application.js //= require select2 # application.css *= require select2 *= require select2-bootstrap ``` 然后,可以使用下面的代码创建select2下拉框: ``` <%= f.select :attribute, options_for_select([["Option 1", 1], ["Option 2", 2], ["Option 3", 3]], @model.attribute), {}, multiple: true, class: "select2" %> <script> $(document).ready(function() { $('.select2').select2(); }); </script> ``` 在这个例子中,我们将select2应用于多选下拉框,它会在下拉菜单中添加搜索框,并使用户能够更容易地查找选项。 希望这些技巧对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值