繁体   English   中英

Active Storage public_url 不返回 key/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 与应用程序中的特定记录连接(基本上, avatarblob@userrecord ,它们通过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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM