在最新的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为什么不行呀
和你反代服务器的延时和配置有关系吧