我已经按照您的描述编辑了 Cloud Run python 示例
import os
from flask import Flask
from flask_cors import CORS
app = Flask(__name__)
CORS(app, resources={r"/*": {"origins": "*"}})
@app.route('/')
def hello_world():
return 'Hello, world!\n'
if __name__ == "__main__":
app.run(debug=True,host='0.0.0.0',port=int(os.environ.get('PORT', 8080)))
我可以access-control-allow-origin: *
在 Cloud Run 上本地和远程获取标头。
docker run --rm -i -e PORT=8080 -p 8080:8080 gcr.io/ahmetb-samples-playground/run/cors-test
$ curl -v http://localhost:8080
< HTTP/1.1 200 OK
< Server: gunicorn/19.9.0
< Date: Mon, 22 Apr 2019 18:23:06 GMT
< Connection: keep-alive
< Content-Type: text/html; charset=utf-8
< Content-Length: 14
< Access-Control-Allow-Origin: *
云跑:
$ curl -v https://cors-test-dpyb4duzqq-uc.a.run.app
< HTTP/2 200
< content-type: text/html; charset=utf-8
< access-control-allow-origin: *
< x-cloud-trace-context: 8503b029795fdc57bbc4267961806847;o=1
< date: Mon, 22 Apr 2019 18:23:30 GMT
< server: Google Frontend
< content-length: 14
两个响应都带有access-control-allow-origin
应用程序中设置的标头。Cloud Run 不会删除此标头。
我不确定 GCS CORS 权限如何/为什么与这个问题相关。如果您想直接从 GCS 存储桶提供网站,请阅读在 GCS 上托管静态网站。
如果您只是将请求从 Cloud Run 代理到 GCS,是的,它可能会从 GCS 响应中继承 CORS 标头。我建议您检查这些标题。