Google Cloud Storage 提供了以下选项的存取控制:
IAM权限:允许存取 Project 里的所有 bucket 和 object。通过 IAM,您可以控制对整个 project 所有 bucket 和 object 的存取权限, 但是无法针对个别 bucket 或是 object 做控制。
Access control list(ACL):允许对单个 bucket 和 objects 进行读写的控制。当您需详细地控制个别的资源时,可以使用 ACL。
Signed URL:通过产生的 URL 网址可以进行存取和读写。无论取得共享网址的人是否拥有 Google 帐户,每个取得共享网址的人皆可在特定的时间存取 object。
Signed policy document:指定可以上传到 bucket 的内容。在 Policy 文件中,可以比 Signed URL 更精准地掌握例如:文件大小、内容类型等上传属性。网站拥有者可通过 Signed policy document 允许访问者将文件上传到 Google Cloud Storage。
本文将介绍如何是用第三种方法:Signed URL 来对 Object 进行上传下载。
一 、创建 Service Account
Service Account 是 Machine to Machine 通讯时,权限管理的账号。我们通过以下三步获得具有存储管理权限的 Service Account:
创建 Service Account
授权 Service Account
下载 Service Account Key 文件
在客户端激活 Service Account
1 创建 Service Account
在 GCP 的 Console 中选择 IAM->Service Account,选择 Create Service Account:
data:image/s3,"s3://crabby-images/d8eee/d8eee3644b62a2634fa498d46848ac9022c412d9" alt=""
data:image/s3,"s3://crabby-images/34c3a/34c3a59c3e89156afab03ed13ec0c4de230e40f4" alt=""
data:image/s3,"s3://crabby-images/4780d/4780da2979120d8fa9c67df069919c7267b03d4c" alt=""
2 授权 Service Account
创建好 Service Account 后,在 IAM 中对这个 Service Account 进行授权。
data:image/s3,"s3://crabby-images/dd28c/dd28cbcc69d70393a98207b807bbd8b6807aecd1" alt=""
data:image/s3,"s3://crabby-images/93225/93225b30358280c489c839f83f82810b31f6e175" alt=""
给这个 Service Account 分配 Storage Admin 的权限。此时在 GCS 的 Permission 中可以看到这个 Service Account 对每个 Bucket 都有了 Admin 的权限。
也可以采用真的每个 Bucket 单独授权的模式,在 IAM 中取消这个 Service Account 的权限。进入到 GCS 管理界面,针对每个 Bucket 进行授权。
3 下载 Service Account Key 文件
在 IAM 的 Service Account 中创建 Service Account Key:
data:image/s3,"s3://crabby-images/60cf9/60cf9b21a54ed84fe260acea5d625b205f8a82c6" alt=""
data:image/s3,"s3://crabby-images/dd459/dd4593b4851d2753973819eee0ef70cde05c69ee" alt=""
这个文件会下载到本地。
4 在客户端激活 Service Account
在安装有 gcloud 客户端的机器上激活 Service Account:
data:image/s3,"s3://crabby-images/8e738/8e738e1b52bbe7a87da7ac3309e02f8a7324b85b" alt=""
二 采用 Signed URL 下载文件
1 查看下载文件
通过 GCS 的命令行工具 gsutil,创建 Signed URL 的链接。
我们对非 public 对文件进行 Signed URL 操作:
data:image/s3,"s3://crabby-images/88f71/88f71034c9ccd6186b8dac69b665c695fc5f38a5" alt=""
2 生成 Signed URL
在命令行中:
data:image/s3,"s3://crabby-images/ac233/ac233944eac102d3f3217698bcdb9fcf4d6dc0e0" alt=""
可以看到 GCP 返回 Signed URL 链接:
data:image/s3,"s3://crabby-images/59f97/59f97ac76bf1991adacf333a01393b7650350ab2" alt=""
3 使用 Signed URL 下载文件
用浏览器打开这个链接,可以直接下载;也可以用 curl 命令手工下载:
data:image/s3,"s3://crabby-images/a8881/a88817512bd4a650182ab3a3394a6f2142edc875" alt=""
data:image/s3,"s3://crabby-images/fb99b/fb99b2f6ce85ebf398b7aa1abf660b3c692273ce" alt=""
三 用 Signed URL 上传文件
1 生成一个上传文件
data:image/s3,"s3://crabby-images/fb99b/fb99b2f6ce85ebf398b7aa1abf660b3c692273ce" alt=""
2 使用 gsutil 生成 signed URL
data:image/s3,"s3://crabby-images/428cf/428cfb50dc7aeca0035387b4d9343873ef437259" alt=""
3 上传文件
data:image/s3,"s3://crabby-images/4f627/4f6272425e471fd0733db02fd2878bb1253fbc79" alt=""
可以看到上传成功。
四 用 Signed URL 实现断点续传上传文件
GCS Signed URL 支持断点续传。具体实现方式如下:
1 生成文件
data:image/s3,"s3://crabby-images/9f0e0/9f0e098a37250a58a78cb047749f7201a2086f57" alt=""
2 gsutil 生成 Signed URL
data:image/s3,"s3://crabby-images/957b9/957b9c50d976834b91a509d0b8f3e2c50ad444d2" alt=""
得到如下返回
data:image/s3,"s3://crabby-images/5ea52/5ea525859c5e3374b2284de61a60147b2b541d98" alt=""
3 生成上传链接
data:image/s3,"s3://crabby-images/6bb7f/6bb7fedb7fbfb3969826f0d69906cf7b7d21a848" alt=""
返回如下:
data:image/s3,"s3://crabby-images/134d8/134d83f0bce670f66f1ea026f4b0e725d057f47c" alt=""
将上传地址取出:
data:image/s3,"s3://crabby-images/3b84e/3b84ec58db8294b7426160b89881861ab42ee35c" alt=""
4 上传并中断
data:image/s3,"s3://crabby-images/639f8/639f8ec1c00e1e2de39a0581cf4348b70cf31c05" alt=""
中断上传
data:image/s3,"s3://crabby-images/80423/804232be01a365c5815fdb9bfe53f12e9133416b" alt=""
5 查看上传的大小
data:image/s3,"s3://crabby-images/76be7/76be72648bc3e5db9b61a0368096d0497b59552d" alt=""
返回值中有 Range 信息:
data:image/s3,"s3://crabby-images/85a45/85a453ef5bff66734011e426010f0e05a5ee14fe" alt=""
6 生成剩余文件
data:image/s3,"s3://crabby-images/92c96/92c968cc859cac0f0df8475e86481b81b447725e" alt=""
7 上传剩余文件
data:image/s3,"s3://crabby-images/1317c/1317c12da59874dd1c716f7ac424d16bcf861634" alt=""
8 验证
data:image/s3,"s3://crabby-images/32010/32010334935657ce92ba94114ec42dde05358742" alt=""
上传的文件和本地文件一致。
五 总结
通过 Signed URL 可以实现:
下载
上传
支持断点续传的上传
文章信息
相关推荐
data:image/s3,"s3://crabby-images/25a23/25a238475b6aa2449beeb9a8d5d3f6af3414c03e" alt=""