我有一个文件,我想提供在线下载,但仅限于选定的用户.
这是我想到的典型场景
想要该文件的人通常会访问该网站并填写表格以请求访问该文件.
如果我想与他/她共享该文件,我会授权用户生成一个唯一的链接,该链接将通过电子邮件发送给用户.该链接仅在特定时间段内有效.
我会使用rails来做这件事.我正在寻找的答案:
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)
此代码未经测试,但它应涵盖您需要的大部分内容,并让您了解您想要采取的方向.
补充阅读:
| 归档时间: |
|
| 查看次数: |
1358 次 |
| 最近记录: |