![](/img/trans.png)
[英]Nginx 404 for /rails/active_storage/blobs/*filename(extension)
[英]Active Storage public_url not returning key/filename.extension
此 PR 中将公共选项添加到 Active Storage: https : //github.com/rails/rails/pull/36729
在里面他清楚地说: “在公共存储桶中,目录结构是/[key]/[filename]”
这是有道理的,正是我想要的。 我希望能够(例如)将链接通过电子邮件发送给某人并允许他们下载文件。 所以我需要文件名.extension。 但是当我启动 Rails 6.1 应用程序时,上传到我的存储桶的文件名后面没有。 这些文件确实出现在我的存储桶中,但仅作为它们的密钥。 不是密钥/文件名。
amazon:
service: S3
access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %>
secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %>
region: us-east-1
bucket: mybucket
public: true
上传工作正常。 文件已上传并出现在我的存储桶中。 但在视图<%= @user.avatar.url %>
返回https://s3.amazonaws.com/mybucket/g3ci2umbfj6wkxyggx7arhekxfib
我希望它返回https://s3.amazonaws.com/mybucket/g3ci2umbfj6wkxyggx7arhekxfib/myfile.png
这真的让我很烦,因为在 PR 中作者明确指出公共文件保存为 key/filename.extension
所以问题是:在 Rails 6.1 中, url
方法是否将文件名作为路径的一部分返回。 如果不是,作者为什么说它是? 如果没有,还有比修补key
更好的方法吗?
域名注册地址:
= link_to @user.avatar.filename, rails_blob_path(@user.avatar, disposition: "course.avatar"), target: :_blank
会给你一个下载链接,比如https://corsego-production.s3.eu-central-1.amazonaws.com/3gbpl68kckpkyrbjoslsl254th0u?response-content-disposition=inline&X-Amz-Security-Token=IQoJb3JpZ2luX2VjEGgaCmV1LBuuKkri8zL3ohM4h9STzhTsnavAgulrcpBavL0POXg%3D%3D&X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20201002T170820Z&X-Amz-SignedHeaders=host&X-Amz-Expires=300&X-Amz-Credential=ASIA5RINJ20201002%2Feu-central-1%2Fs3%2Faws4_request&X-Amz-Signature=0a205d713ebaa9d3ca9d62
@user.avatar.url
不应该返回任何东西!
@user.avatar
应该返回类似#<ActiveStorage::Attached::One:0x00007f15986ee4c0>
使用 Active Storage 创建附件时,有关附件的以下字段会自动填充并保存为active_storage_blobs
:
create_table "active_storage_blobs", force: :cascade do |t|
t.string "key", null: false
t.string "filename", null: false
t.string "content_type"
t.text "metadata"
t.bigint "byte_size", null: false
t.string "checksum", null: false
t.datetime "created_at", null: false
t.index ["key"], name: "index_active_storage_blobs_on_key", unique: true
end
假设您上传了具有活动存储空间的图像。 上表将按以下方式填充:
Id: 1
Key: sy2y1ytw7zob6mwtnwc1552cdp5l
Filename: Screenshot 2020-10-02 125405.png
Content_type: image/png
Metadata: {"identified"=>true, "analyzed"=>true}
Byte_size: 1550
Checksum: mGPerbRMj6LXbPKhqKd4bA
要将用户头像显示为图像,您必须调用= image_tag @user.avatar
= rails_blob_url(@user.avatar)
会给你像https://example.com/rails/active_storage/blobs/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBCZz09IiwiZXhwIjpudWxsLCJwdXIiOiJibG9iX2lkIn19--5fb10a9c8e9f2c4e7099eee21c1dc2ff0343c210/Screenshot%202020-10-02%20125405.png
= @user.avatar
会给你类似#<ActiveStorage::Attached::One:0x00007f1589293dd0>
= url_for(@user.avatar)
会给你像/rails/active_storage/blobs/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBCZz09IiwiZXhwIjpudWxsLCJwdXIiOiJibG9iX2lkIn19--5fb10a9c8e9f2c4e7099eee21c1dc2ff0343c210/Screenshot%202020-10-02%20125405.png
active_storage 创建的迁移中的第二个表是这样的:
create_table "active_storage_attachments", force: :cascade do |t|
t.string "name", null: false
t.string "record_type", null: false
t.bigint "record_id", null: false
t.bigint "blob_id", null: false
t.datetime "created_at", null: false
t.index ["blob_id"], name: "index_active_storage_attachments_on_blob_id"
t.index ["record_type", "record_id", "name", "blob_id"], name: "index_active_storage_attachments_uniqueness", unique: true
end
基本上,它将 blob 与应用程序中的特定记录连接(基本上, avatar
是blob
, @user
是record
,它们通过active_storage_attachments
表关联。
所以你也可以在@user.avatar 方法上运行以下命令:
@user.avatar.name #Avatar
@user.avatar.record_type #User
@user.avatar.record_id #2 (user id)
@user.avatar.blob_id #1 (blob id)
现在,以下是存储在 AWS S3 上的上述文件的示例 URL: https : //corsego-production.s3.eu-central-1.amazonaws.com/3gbpl68kckpkyrbjoslsl254th0u? response-content-disposition = inline & X-Amz- Security-标记= IQoJb3JpZ2luX2VjEGgaCmRzBFAiBSJ2QIEqs1opj%2BuCR74CDMt67ueDTTQIhAOJGGy2wfmxmGUwpQe9cyc84ZhUhuWKHdVgTUctbtGrVKdinkpg0w7OikcyNYpnbq%2FefcTmEgRvIlPO%2B0itFxUr8mKUvnDYSuKkri8zL3ohM4h9STzhTsnavAgulrcpBavL0POXg%3D%3D&X-AMZ-算法= AWS4-HMAC-SHA256&X-AMZ-日期= 20201002T170820Z&X-AMZ-SignedHeaders =宿主&X-AMZ-过期= 300&X-AMZ-凭证= ASIA5RINJLY2F20201002%2Feu- central-2%2Fs3%2Faws4_request&X-Amz-Signature=0a205d713ebaaa339ad4ee09db9dfe16986e69d3ca9d62
查看 url 如何包含秘密令牌和到期时间? 建议不要有永久的文件 url。
PS 将 AWS S3 连接到您的应用程序时,不要忘记添加CORS 配置:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.