[我每天都尝试从不存在浏览器访问权限的服务器上将视频上传到我的帐户。我可以在桌面上执行此操作,通过运行以下脚本打开浏览器,询问我的权限,并获得上传视频所需的完整授权,然后上传视频。
python upload_video.py --file clips/concatenated.mp4 --title testing --desc empty_dec
/Users/devansh.dalal/Desktop/hackathon/tiktoki/venv/lib/python3.7/site-packages/oauth2client/_helpers.py:255: UserWarning: Cannot access upload_video.py-oauth2.json: No such file or directory
warnings.warn(_MISSING_FILE_MESSAGE.format(filename))
Your browser has been opened to visit:
https://accounts.google.com/o/oauth2/auth?client_id=73183172161-48495o1tqgjgih3v7j218av2bghdcm30.apps.googleusercontent.com&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2F&scope=https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fyoutube.upload&access_type=offline&response_type=code
If your browser is on a different machine then exit and re-run this
application with the command-line parameter
--noauth_local_webserver
Authentication successful.
Uploading file...
但是我需要一个不需要手动授权脚本的解决方案,因为我的服务器是完全安全的。建议吗?
您可以阅读文档OAuth 2.0 for Mobile & Desktop Apps,以获得有关独立计算机上授权流程的详尽信息。
文档指定steps 4和step 5。通过最初的OAuth流,您将获得两个令牌:短期访问令牌和刷新令牌,刷新令牌可根据需要生成访问令牌。 不可能在没有浏览器的情况下进行验证,但是一旦有了刷新令牌,就可以通过编程将其交换为访问令牌:
初始化:通过浏览器身份验证获取刷新令牌;
迭代:根据需要多次查询API以获取访问令牌-无需任何浏览器交互! -使用(1)中的刷新令牌,然后继续对目标API端点的调用(同样,无需任何浏览器交互)。
注意,步骤(1)和(2)可以很好地分开,以便(1)由将刷新令牌存储到文件中的独立(本地)计算机执行;之后,在另一台远程计算机(例如未安装浏览器的服务器)上安全传输该文件后,请根据需要重复在该远程计算机上执行(2)(请参阅Using OAuth 2.0 for server-side, standalone scripts。)