如何创建一个rails应用程序,通过独特的自动生成链接使文件可访问?

Ank*_*kit 6 ruby-on-rails-3

我有一个文件,我想提供在线下载,但仅限于选定的用户.

这是我想到的典型场景

想要该文件的人通常会访问该网站并填写表格以请求访问该文件.

如果我想与他/她共享该文件,我会授权用户生成一个唯一的链接,该链接将通过电子邮件发送给用户.该链接仅在特定时间段内有效.

我会使用rails来做这件事.我正在寻找的答案:

  1. 生成下载的唯一链接的正确方法是什么?
  2. 当用户在有效时间范围内点击链接时,如何开始下载文件?

Noz*_*Noz 10

首先,您需要设置一个用于存储令牌的模型:

rails g model DownloadToken token:string expires_at:timestamp
Run Code Online (Sandbox Code Playgroud)

download_token.rb

class DownloadToken < ActiveRecord::Base  

   attr_accessible :token, :expires_at
   before_create :generate_token

   def generate_token
      self.token = SecureRandom.base64(15).tr('+/=lIO0', 'abc123')
   end

end
Run Code Online (Sandbox Code Playgroud)

接下来,设置控制器来处理提交的表单(或更改现有操作)并生成令牌,发送电子邮件等.

class FooController < ApplicationController

  def create
    #process submitted form
    ...
    #create a token that expires in 24 hours
    @token = DownloadToken.create(:expires_at => Time.now + 24.hours)
    #send email and redirect..
  end    
end
Run Code Online (Sandbox Code Playgroud)

您需要确保邮件程序视图包含以下内容:

<%= link_to "Click Me", "/files/downloads?token=#{@token.token}" %>
Run Code Online (Sandbox Code Playgroud)

您还需要设置一个负责提供下载的控制器,它应该如下所示:

class FileController < ApplicationController
  before_filter :check_token

  def check_token
    redirect_to :back, :flash => {:error => "Bad link"} if DownloadToken.where("token = ? and expires_at > ?", params[:token], Time.now).nil?
  end

  def download
    send_file '/home/your_app/downloads/yourfile.zip', :type=>"application/zip", :x_sendfile=>true        
  end

end
Run Code Online (Sandbox Code Playgroud)

routes.rb(假设Foo已经设置为RESTful资源)

match 'files/download' => 'files#download'
Run Code Online (Sandbox Code Playgroud)

此代码未经测试,但它应涵盖您需要的大部分内容,并让您了解您想要采取的方向.

补充阅读: