我有一个可以dev_appserver.py
在我的机器上使用的应用程序。我成功部署它:
ronj@l:~$ appcfg.py update myapp/
03:03 PM Host: appengine.google.com
03:03 PM Application: myapp; version: 1
...
03:03 PM Completed update of app: myapp, version: 1
我的应用程序使用 Google API,因此此部署包含一个client_secrets.json
文件,该文件位于我的项目文件夹的根目录中。它似乎已正确部署,因为我在重新下载我的应用程序时得到它(使用appcfg.py download_app -A myapp -V 1 ~/myapp
)。
但是,当打开一个调用需要访问的脚本的页面时client_secrets.json
,我得到一个Error: Server Error
,这是实例日志显示的内容(myapp 和 MYID 被审查):
Traceback (most recent call last):
File "/python27_runtime/python27_lib/versions/1/google/appengine/runtime/wsgi.py", line 196, in Handle
handler = _config_handle.add_wsgi_middleware(self._LoadHandler())
File "/python27_runtime/python27_lib/versions/1/google/appengine/runtime/wsgi.py", line 255, in _LoadHandler
handler = __import__(path[0])
File "/base/data/home/apps/s~myapp/1.MYID/myapp.py", line 42, in <module>
YOUTUBE_READ_WRITE_SCOPE)
File "/base/data/home/apps/s~myapp/1.MYID/oauth2client/util.py", line 128, in positional_wrapper
return wrapped(*args, **kwargs)
File "/base/data/home/apps/s~myapp/1.MYID/oauth2client/appengine.py", line 854, in __init__
client_type, client_info = clientsecrets.loadfile(filename, cache=cache)
File "/base/data/home/apps/s~myapp/1.MYID/oauth2client/clientsecrets.py", line 145, in loadfile
return _loadfile(filename)
File "/base/data/home/apps/s~myapp/1.MYID/oauth2client/clientsecrets.py", line 107, in _loadfile
raise InvalidClientSecretsError('File not found: "%s"' % filename)
InvalidClientSecretsError: File not found: "/base/data/home/apps/s~myapp/1.MYID/client_secrets.json"
这是第 41 和 42 行myapp.py
:
decorator = OAuth2DecoratorFromClientSecrets(CLIENT_SECRETS,
YOUTUBE_READ_WRITE_SCOPE)
这是CLIENT_SECRETS
:
CLIENT_SECRETS = os.path.join(os.path.dirname(__file__), 'client_secrets.json')
我究竟做错了什么?
编辑:#appengine 上的 murph 提到这可能来自不正确的app.yaml
配置,我应该“确保它不是app.yaml
作为静态文件提供,并确保您自己的任何代码都不会决定提供它”,但即使删除该文件的所有静态处理程序后,问题仍然存在。这是我的 app.yaml 的 pastebin。谈到这一点,我注意到如果我离开 client_secrets.json 并部署,我会看到“克隆 6 个静态文件”。然后,如果我删除它并重新部署,我会看到"Cloning 5 static files"。app.yaml
这是否确认我的匹配项中仍有某些内容client_secrets.json
,或者这些单独的机制?