我每天尝试从我的服务器上传视频到我的帐户,但浏览器无法访问。我可以在桌面上执行此操作,通过运行下面提到的脚本打开浏览器,请求我的权限并完成上传视频所需的完整授权,然后上传视频。
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...
但我想要一个不需要手动授权脚本的解决方案,因为我的服务器是完全安全的。请提出建议?
首先请注意,API 上传视频所需的授权与您服务器的安全级别无关。您可以阅读文档适用于移动和桌面应用程序的 OAuth 2.0 https://developers.google.com/youtube/v3/guides/auth/installed-apps有关独立计算机上的授权流程的完整信息。
该文档指定steps 4 https://developers.google.com/youtube/v3/guides/auth/installed-apps#handlingresponse and step 5 https://developers.google.com/youtube/v3/guides/auth/installed-apps#exchange-authorization-code。通过初始 OAuth 流程,您将获得两个令牌:一个短期访问令牌和一个按需生成访问令牌的刷新令牌。没有浏览器无法进行身份验证,但是一旦拥有刷新令牌,就可以通过编程方式交易访问令牌:
初始化:通过浏览器认证获取刷新令牌;
迭代:根据需要多次查询 API 以获得访问令牌——无需任何浏览器交互! -- 使用 (1) 中的刷新令牌,然后进一步调用目标 API 端点(同样,无需任何浏览器交互)。
请注意,步骤(1)和(2)完全可以分开,使得(1)由将刷新令牌存储到文件中的独立(本地)计算机执行;稍后,在另一台远程计算机(例如未安装浏览器的服务器)上安全传输该文件后,根据需要在该远程计算机上重复执行 (2)
(看将 OAuth 2.0 用于服务器端独立脚本 https://developers.google.com/youtube/v3/guides/moving_to_oauth#standalone.)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)