利用cloudflare和自建服务器实现反向代理onedreive,提高国内onedrive下载速度,对接OneDrive
本文最后更新于 1177 天前,其中的信息可能已经有所发展或是发生改变。

利用cloudflare和自建服务器实现反向代理onedreive,提高国内onedrive下载速度,对接OneDrive插图

在最新的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大佬)
附图:利用cloudflare和自建服务器实现反向代理onedreive,提高国内onedrive下载速度,对接OneDrive插图2

把你的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的设置
d3177288b0b5e2f1ef8e2f14b7dc25a7

反代代码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登陆的界面

使用Cloudflare Workers反代OneDrive

反代链接对接Cloudreve

Cloudreve V3.2.1版本加入了OneDrive反代功能,对接存储时把反代链接填上就行

使用Cloudflare Workers反代OneDrive

方法二:

如果你拥有一台闲置的,带宽和流量都比较大(但是硬盘小)的服务器

你就可以使用这种方法来反向代理加速 OneDrive 了!

开始

服务器安装好 Nginx 或是 Caddy 等支持反向代理的软件(Caddy的反向代理较简单,教程以 Nginx 为例)

使用宝塔面板创建反向代理

1.直接添加站点,不需要FTP不需要数据库,PHP版本可以选择为纯静态

2.设置站点,配置Nginx反向代理,加速上传下载

45e5969a492590950c39de9fe909b238

以上图为例,A代表我们的中转,B代表我们,C代表onedrive,我们直接从onedrive那边下载东西的时候速度很慢,而此时我们的中转服务器A到onedrive的速度很快,我们从服务器A上下东西也快,那么我们可以借助A来提高获取onedrive文件的下载速度。

配置反代网站

假设我的反代网站是proxy.abc.xyz

先解析该网址至服务器192.168.1.2,然后在服务器内用宝塔新建网站,再申请ssl证书(必须)

先查看并记下微软分配的全局域名,形如

https://xxx-my.sharepoint.com

d18aa5ddb15900c8713822fdd2cc7c11

3.查看微软分配的全局域名的方法:打开自己的onedrive ,随意下载一个文件,然后在下载列表中右键点击下载的文件,选择【复制链接地址】

利用cloudflare和自建服务器实现反向代理onedreive,提高国内onedrive下载速度,对接OneDrive插图14

4.截选出上图红框中的部分

复制出的链接:
https://c*****e-my.sharepoint.com/personal/*****com/_layouts/15/download.aspx?UniqueId=e46c6e……
截选的部分:
https://c*****e-my.sharepoint.com

5.把截选出来的部分填入步骤2的【目标url】中,提交即可

利用cloudflare和自建服务器实现反向代理onedreive,提高国内onedrive下载速度,对接OneDrive插图16

6.测试刚刚建的站是否能正常访问

直接浏览器访问 http://yours.domainname.com (或使用了ssl后 https://yours.domainname.com )

打开后白屏的话等待一会儿,直到跳转到微软的登录界面即为成功

这里以https://2demo-my.sharepoint.com为例

在宝塔面板中配置反向代理网站。

c571a83c78d42a5766e737fe38c8314f

提交后再点击反向代理的配置文件添加禁止缓存代码

proxy_buffering off; ​ proxy_cache off; ​ proxy_set_header X-Forwarded-Proto $scheme;

39ae7b7adfd64930b1c9c7794623065f

然后在网站的配置文件中添加下面两行代码

de70a0a0a3124efcf7792bf3a7ba9aec

sub_filter "2demo-my.sharepoint.com" "proxy.abc.xyz";

sub_filter_once off;

注意以上代码涉及到域名的请修改成自己的域名

 

评论

  1. 3 年前
    2021-9-16 1:52:45

    方法一的代码2为什么不行呀

    • zzkuner 博主
      2 年前
      2021-10-30 10:16:54

      和你反代服务器的延时和配置有关系吧

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇