随着流量的增加,GCP App Engine 会自动为应用分配更多的资源,但自动分配资源仍然受到一些阀值的约束,其中一条便是:发送到应用的请求,请求体不能大于32M。而对于一些上传大文件的需求,这个限制使得那些将文件上传服务的 EndPoint 设置在 App Engine 上的应用无法正常处理请求。
考虑到 App Engine 不允许应用操作本地存储,而且我们上传的文件一般也不会保存在本地,而是存到 Cloud Storage,File Store 等地方。
这里以 Cloud Storage 为例,Cloud Storage 提供了Signed URLs(除了失效时间之外,可以不受任何约束)访问 Storage 中的资源。这种方式在进行签名时需要将Content-Type
用作签名的一部分,然而对于mutlipart/formdata
类型的表单,Content-Tyep 是 mutlipart/formdata ---boundaryString
的形式,而 boundaryString 是动态生成的,这就导致无法为文件上传请求进行签名。
在这个 questions 中也可以看到有人给出了解决方案,那就是使用 post-object#policydocument。
看如下的示例:
<form action="https://storage.googleapis.com/bucket-name/file-name" method="post" enctype="multipart/form-data">
<input type="hidden" name="GoogleAccessId" value="1234567890123@developer.gserviceaccount.com">
<input type="hidden" name="policy" value="eyJleHBpcmF0aW9uIjogIjIwMTA