在最新的cloudreve中添加了可以为 OneDrive 指定自建反代下载服务器的功能
方法一:
cloudreve搭建方法就不赘述了。
反正是go语言编译出来的,
官方文档也很齐全(有手 就行 )
怎么对接onedrive也不说了
具体的看我的这个链接 :https://blog.zzk.zone/2020/07/25/224/
反代代码1
关键在于OneDrive的反代及加速
贴上代码地址:https://github.com/EtherDream/jsproxy/blob/master/cf-worker/index.js (感谢Lemon0大佬)
附图:
把你的onedrive直链https://*-my.sharepoint.com/地址替换到代码中标注地址。
最后把workers部署发布然后绑定一个通过cname接入的域名。
举个例子:
我用萌精灵 把*.com 解析到 1.0.0.1 (这里ip可以随便填,等会儿会加入workers路由),再通过cname接入到国内解析平台。
在dns运营商自选ip上,我选用了cf2dns的项目(免费版本会延迟1天的数据,收费版本1快1000次),
通过解析后dnspod或者阿里dns后,大部分地方的速度都能拉起来(有些玄学的地方是在没办法),
需要注意的是:cf2dns是作者部署在国内的机器选取质量上佳的ip,但机器有限,选取的IP单一,所以不能以一概全。
最后workers绑定域名。
附上cloudreve的设置
反代代码2
// 替换成你OneDrive的网址 const upstream = '*-my.sharepoint.com' // 替换成你OneDrive的网址 const upstream_mobile = '*-my.sharepoint.com' // 下面的配置都不用动 const upstream_path = '/' const blocked_region = ['KP', 'SY', 'PK', 'CU'] const blocked_ip_address = ['0.0.0.0', '127.0.0.1'] const https = true const disable_cache = false const replace_dict = { '$upstream': '$custom_domain', '//sunpma.com': '' } addEventListener('fetch', event => { event.respondWith(fetchAndApply(event.request)); }) async function fetchAndApply(request) { const region = request.headers.get('cf-ipcountry').toUpperCase(); const ip_address = request.headers.get('cf-connecting-ip'); const user_agent = request.headers.get('user-agent'); let response = null; let url = new URL(request.url); let url_hostname = url.hostname; if (https == true) { url.protocol = 'https:'; } else { url.protocol = 'http:'; } if (await device_status(user_agent)) { var upstream_domain = upstream; } else { var upstream_domain = upstream_mobile; } url.host = upstream_domain; if (url.pathname == '/') { url.pathname = upstream_path; } else { url.pathname = upstream_path + url.pathname; } if (blocked_region.includes(region)) { response = new Response('Access denied: WorkersProxy is not available in your region yet.', { status: 403 }); } else if (blocked_ip_address.includes(ip_address)) { response = new Response('Access denied: Your IP address is blocked by WorkersProxy.', { status: 403 }); } else { let method = request.method; let request_headers = request.headers; let new_request_headers = new Headers(request_headers); new_request_headers.set('Host', upstream_domain); new_request_headers.set('Referer', url.protocol + '//' + url_hostname); let original_response = await fetch(url.href, { method: method, headers: new_request_headers }) connection_upgrade = new_request_headers.get("Upgrade"); if (connection_upgrade && connection_upgrade.toLowerCase() == "websocket") { return original_response; } let original_response_clone = original_response.clone(); let original_text = null; let response_headers = original_response.headers; let new_response_headers = new Headers(response_headers); let status = original_response.status; if (disable_cache) { new_response_headers.set('Cache-Control', 'no-store'); } new_response_headers.set('access-control-allow-origin', '*'); new_response_headers.set('access-control-allow-credentials', true); new_response_headers.delete('content-security-policy'); new_response_headers.delete('content-security-policy-report-only'); new_response_headers.delete('clear-site-data'); if (new_response_headers.get("x-pjax-url")) { new_response_headers.set("x-pjax-url", response_headers.get("x-pjax-url").replace("//" + upstream_domain, "//" + url_hostname)); } const content_type = new_response_headers.get('content-type'); if (content_type != null && content_type.includes('text/html') && content_type.includes('UTF-8')) { original_text = await replace_response_text(original_response_clone, upstream_domain, url_hostname); } else { original_text = original_response_clone.body } response = new Response(original_text, { status, headers: new_response_headers }) } return response; } async function replace_response_text(response, upstream_domain, host_name) { let text = await response.text() var i, j; for (i in replace_dict) { j = replace_dict[i] if (i == '$upstream') { i = upstream_domain } else if (i == '$custom_domain') { i = host_name } if (j == '$upstream') { j = upstream_domain } else if (j == '$custom_domain') { j = host_name } let re = new RegExp(i, 'g') text = text.replace(re, j); } return text; } async function device_status(user_agent_info) { var agents = ["Android", "iPhone", "SymbianOS", "Windows Phone", "iPad", "iPod"]; var flag = true; for (var v = 0; v < agents.length; v++) { if (user_agent_info.indexOf(agents[v]) > 0) { flag = false; break; } } return flag; }
自己自定义前缀,点击保存并部署,会得到一个网址 https://*.*.workers.dev/
此时打开链接应该是office登陆的界面
反代链接对接Cloudreve
Cloudreve V3.2.1版本加入了OneDrive反代功能,对接存储时把反代链接填上就行
方法二:
如果你拥有一台闲置的,带宽和流量都比较大(但是硬盘小)的服务器
你就可以使用这种方法来反向代理加速 OneDrive 了!
开始
服务器安装好 Nginx 或是 Caddy 等支持反向代理的软件(Caddy的反向代理较简单,教程以 Nginx 为例)
使用宝塔面板创建反向代理
1.直接添加站点,不需要FTP不需要数据库,PHP版本可以选择为纯静态
2.设置站点,配置Nginx反向代理,加速上传下载
以上图为例,A代表我们的中转,B代表我们,C代表onedrive,我们直接从onedrive那边下载东西的时候速度很慢,而此时我们的中转服务器A到onedrive的速度很快,我们从服务器A上下东西也快,那么我们可以借助A来提高获取onedrive文件的下载速度。
配置反代网站
假设我的反代网站是proxy.abc.xyz
先解析该网址至服务器192.168.1.2,然后在服务器内用宝塔新建网站,再申请ssl证书(必须)
先查看并记下微软分配的全局域名,形如
https://xxx-my.sharepoint.com
3.查看微软分配的全局域名的方法:打开自己的onedrive ,随意下载一个文件,然后在下载列表中右键点击下载的文件,选择【复制链接地址】
4.截选出上图红框中的部分
如
5.把截选出来的部分填入步骤2的【目标url】中,提交即可
6.测试刚刚建的站是否能正常访问
直接浏览器访问 http://yours.domainname.com (或使用了ssl后 https://yours.domainname.com )
打开后白屏的话等待一会儿,直到跳转到微软的登录界面即为成功
这里以https://2demo-my.sharepoint.com
为例
在宝塔面板中配置反向代理网站。
提交后再点击反向代理的配置文件添加禁止缓存代码
proxy_buffering off;
proxy_cache off;
proxy_set_header X-Forwarded-Proto $scheme;
然后在网站的配置文件中添加下面两行代码
sub_filter "2demo-my.sharepoint.com" "proxy.abc.xyz";
sub_filter_once off;
注意以上代码涉及到域名的请修改成自己的域名
方法一的代码2为什么不行呀
和你反代服务器的延时和配置有关系吧