data:image/s3,"s3://crabby-images/6db62/6db62a9c8584e5252d7d22122fb90fb5409f134d" alt="Google Cloud Storage Signed URL"
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/45f3e/45f3e04ad73b6b6c1e999a3269d7c75969002468" alt=""
data:image/s3,"s3://crabby-images/9f3aa/9f3aa952e7c546ad963d5664bc22922560dccbc4" alt=""
data:image/s3,"s3://crabby-images/fe55a/fe55a3c75a5a225b9df603e694af9dab1d06d9d0" alt=""
2 授权 Service Account
创建好 Service Account 后,在 IAM 中对这个 Service Account 进行授权。
data:image/s3,"s3://crabby-images/d1f90/d1f90e97a0d77c774a618d95ac37a612bc8665e9" alt=""
data:image/s3,"s3://crabby-images/8b224/8b22489b5d625596fd01cc518ebe9647c5eb1ff1" 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/f0ff1/f0ff1eb6262c0374b968c78a5d298c6007efb2fa" alt=""
data:image/s3,"s3://crabby-images/c8512/c8512c90e791051434c73dac31f6ef61eab048e8" alt=""
这个文件会下载到本地。
4 在客户端激活 Service Account
在安装有 gcloud 客户端的机器上激活 Service Account:
data:image/s3,"s3://crabby-images/3cd78/3cd782bbc71ba8abaef2eb8d9f25d2ce59f90beb" alt=""
二 采用 Signed URL 下载文件
1 查看下载文件
通过 GCS 的命令行工具 gsutil,创建 Signed URL 的链接。
我们对非 public 对文件进行 Signed URL 操作:
data:image/s3,"s3://crabby-images/04faa/04faaafc43efb7fa011a8aa990a50dc24f0d179d" alt=""
2 生成 Signed URL
在命令行中:
data:image/s3,"s3://crabby-images/9396c/9396cbc50022149f84fbb597020bfe18e63a744b" alt=""
可以看到 GCP 返回 Signed URL 链接:
data:image/s3,"s3://crabby-images/4b5e7/4b5e78ed072ea4fa5406b6e5e426a524ec09fc23" alt=""
3 使用 Signed URL 下载文件
用浏览器打开这个链接,可以直接下载;也可以用 curl 命令手工下载:
data:image/s3,"s3://crabby-images/f258b/f258b2effcb105d81431e67a460c80a973e13c29" alt=""
data:image/s3,"s3://crabby-images/cd35c/cd35c2724134791d69fab1d08cbc5a6bc24ac31d" alt=""
三 用 Signed URL 上传文件
1 生成一个上传文件
data:image/s3,"s3://crabby-images/cd35c/cd35c2724134791d69fab1d08cbc5a6bc24ac31d" alt=""
2 使用 gsutil 生成 signed URL
data:image/s3,"s3://crabby-images/b7b20/b7b20148083d65c811c1e205e14e5c15abce8202" alt=""
3 上传文件
data:image/s3,"s3://crabby-images/222c9/222c9da72b70e9c939e30c27165c66f71636a514" alt=""
可以看到上传成功。
四 用 Signed URL 实现断点续传上传文件
GCS Signed URL 支持断点续传。具体实现方式如下:
1 生成文件
data:image/s3,"s3://crabby-images/0bb8b/0bb8b61a7c5a31191adfdb9e33230781c6c646ff" alt=""
2 gsutil 生成 Signed URL
data:image/s3,"s3://crabby-images/adf05/adf0504180c5c5c7f2053b8c0aa6e22809b8f920" alt=""
得到如下返回
data:image/s3,"s3://crabby-images/2672e/2672e72867b6e20a2a52c16e7e1e77a85d70f15d" alt=""
3 生成上传链接
data:image/s3,"s3://crabby-images/68df4/68df4ae8bc9b7045c68bd8ff93e94432d51c29eb" alt=""
返回如下:
data:image/s3,"s3://crabby-images/8b132/8b132dc2af9ca05880e5e22053d1b94af3e07e72" alt=""
将上传地址取出:
data:image/s3,"s3://crabby-images/6d8c9/6d8c9d0147ae60eed993eb28d0c12cbe00661261" alt=""
4 上传并中断
data:image/s3,"s3://crabby-images/ad8c3/ad8c360fb84f03c1141e50f90d24b7fbfb91a728" alt=""
中断上传
data:image/s3,"s3://crabby-images/d24ef/d24ef42e932fe38ef8381f976c8105fdfd5c721c" alt=""
5 查看上传的大小
data:image/s3,"s3://crabby-images/f4288/f4288cece15f1fd59d344067e753724cdd1c511a" alt=""
返回值中有 Range 信息:
data:image/s3,"s3://crabby-images/6d818/6d818b3b8566123bc6e52eaa94efb45796077100" alt=""
6 生成剩余文件
data:image/s3,"s3://crabby-images/ac30f/ac30fc621c50b66396cc3bac3543ed178696e007" alt=""
7 上传剩余文件
data:image/s3,"s3://crabby-images/7675f/7675ff61e500e477cc05ec73990f247589340ae6" alt=""
8 验证
data:image/s3,"s3://crabby-images/ee79c/ee79cb47a00a33a9ed5361ef015fa15acc866727" alt=""
上传的文件和本地文件一致。
五 总结
通过 Signed URL 可以实现:
下载
上传
支持断点续传的上传
评论