OneDrive Index,是一款可以直接部署在Cloudflare Workers,不需要服务器就可以运行的直链程序。最近的更新中支持了由Cloudflare反代下载OneDrive文件,大大缓解了国内电信和移动用户的下载缓慢问题。
一个Cloudflare账号,一个OneDrive国际版账号
首先到Cloudflare注册一个账号,由于Cloudflare页面有中文语言,注册也很简单,所以这里不再演示(我懒,我懒还不行么嘤嘤嘤)
然后到这里新建一个应用程序。
注册时会要求填写应用程序名以及调整一些设置,应用程序名任意填写即可,把“受支持的账户类型”调整为第三项“所有 Microsoft 帐户用户”,重定向URL改为Web,网址填写https://heymind.github.io/tools/microsoft-graph-api-auth并点击注册。
接下来,我们到“证书和密码”选项卡,新建一套证书和密码。点击左侧的“证书和密码”,然后点击新客户端密码。
在新客户端密码这里,说明可以随意填写,截止期限这里,为了使其长久可用,我们最好设为从不,最后点击添加即可。
创建完成之后,客户端密码这里就会多出一个值,我们点右侧的复制按钮把它复制下来并妥善保存,待用。
随后我们进入API权限选项卡,把我们需要的API权限添加进来。点左侧的Microsoft Graph,然后在弹出框中添加入offline_access, Files.Read, Files.Read.All这三个权限,最后点击更新权限即可。
接着我们回到“概要”选项卡,把应用程序(客户端)ID复制下来。然后我们进入Microsoft Graph API Auth来获取一个token。
复制之后,我们回到token获取工具,看到4. Authorize for code,在第一行处把刚才复制的ID粘贴进去,第二行和第三行保持默认(与图上一致),然后点AUTHORIZE。
然后会进入office的登录和授权页面,登录自己账号并点击授权即可。
授权结束后,回到刚才的获取工具,看5. Exchange Access Token,还有一个Client Secret未填写,在这里我们把之前保存的密码填进去。
全部填写完成后,点GET TOKEN(注意全程操作不可以太慢,否则会导致授权失效,然后获取token报错,如果真的报错了,可以返回授权步骤重新登录授权。在获取到token后,在页面中找到refresh token,把其后面引号内的内容复制下来并妥善保存。
从此,微软这边的操作完成,然后我们来到这个直链程序的github发布页,把程序代码全部复制下来。
然后我们来到cloudflare的主页,打开workers。
然后我们创建一个新的worker,worker的名字可以随意修改,然后我把github上复制的程序代码粘贴进去(不保留worker内预留的代码)
然后看程序代码中第6、7、8行的refresh_token、client_id和client_secret,其中第一项填刚才找出来的大长串token,第二个填在微软那里复制的应用程序(客户端)ID,第三个填之前保存的密码,全部填好后,再看第13行的base(代表显示的根目录),一般我们该为/,就是直接显示OneDrive的根目录,如果需要显示你OneDrive内某个特定目录,在这里填你需要显示的文件夹名称即可。点击保存并部署,等待片刻后即可访问。
最后我们在浏览器输入这个网址,就可以访问啦~
这里说明一下,程序默认点击下载为直连下载(就是不通过cloudflare),如果需要通过cloudflare反代下载,需要在复制文件下载链接后,在链接尾部加上?proxied,就可以通过cloudflare反代下载了。
还有这里不得不说,由于这个程序在设计上的原理特殊性,下载时不能开启多线程而且不能显示进度,可以看到下载速度还是比较慢的(本来我联通直连OneDrive下载就能满速,cloudflare反代却搞成这样子,委屈屈╥﹏╥…),不过对于移动和电信来说,至少保存 保证了绝大部分用户的正常下载,还是有意义的。
教程结束