【保姆级】0成本搭建个人专属高速网络通道!手机电脑通用,实测跑满千兆宽带!


注册账号

1.官网注册Cloudflare ,新建Workers项目,复制粘贴代码。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
const WS_READY_STATE_OPEN = 1;
const WS_READY_STATE_CLOSING = 2;
const CF_FALLBACK_IPS = ['[2a00:1098:2b::1:6815:5881]'];

// 复用 TextEncoder,避免重复创建
const encoder = new TextEncoder();

import { connect } from 'cloudflare:sockets';

export default {
async fetch(request, env, ctx) {
try {
const token = '';
const upgradeHeader = request.headers.get('Upgrade');

if (!upgradeHeader || upgradeHeader.toLowerCase() !== 'websocket') {
return new URL(request.url).pathname === '/'
? new Response('WebSocket Proxy Server', { status: 200 })
: new Response('Expected WebSocket', { status: 426 });
}

if (token && request.headers.get('Sec-WebSocket-Protocol') !== token) {
return new Response('Unauthorized', { status: 401 });
}

const [client, server] = Object.values(new WebSocketPair());
server.accept();

handleSession(server).catch(() => safeCloseWebSocket(server));

// 修复 spread 类型错误
const responseInit = {
status: 101,
webSocket: client
};

if (token) {
responseInit.headers = { 'Sec-WebSocket-Protocol': token };
}

return new Response(null, responseInit);

} catch (err) {
return new Response(err.toString(), { status: 500 });
}
},
};

async function handleSession(webSocket) {
let remoteSocket, remoteWriter, remoteReader;
let isClosed = false;

const cleanup = () => {
if (isClosed) return;
isClosed = true;

try { remoteWriter?.releaseLock(); } catch {}
try { remoteReader?.releaseLock(); } catch {}
try { remoteSocket?.close(); } catch {}

remoteWriter = remoteReader = remoteSocket = null;
safeCloseWebSocket(webSocket);
};

const pumpRemoteToWebSocket = async () => {
try {
while (!isClosed && remoteReader) {
const { done, value } = await remoteReader.read();

if (done) break;
if (webSocket.readyState !== WS_READY_STATE_OPEN) break;
if (value?.byteLength > 0) webSocket.send(value);
}
} catch {}

if (!isClosed) {
try { webSocket.send('CLOSE'); } catch {}
cleanup();
}
};

const parseAddress = (addr) => {
if (addr[0] === '[') {
const end = addr.indexOf(']');
return {
host: addr.substring(1, end),
port: parseInt(addr.substring(end + 2), 10)
};
}
const sep = addr.lastIndexOf(':');
return {
host: addr.substring(0, sep),
port: parseInt(addr.substring(sep + 1), 10)
};
};

const isCFError = (err) => {
const msg = err?.message?.toLowerCase() || '';
return msg.includes('proxy request') ||
msg.includes('cannot connect') ||
msg.includes('cloudflare');
};

const connectToRemote = async (targetAddr, firstFrameData) => {
const { host, port } = parseAddress(targetAddr);
const attempts = [null, ...CF_FALLBACK_IPS];

for (let i = 0; i < attempts.length; i++) {
try {
remoteSocket = connect({
hostname: attempts[i] || host,
port
});

if (remoteSocket.opened) await remoteSocket.opened;

remoteWriter = remoteSocket.writable.getWriter();
remoteReader = remoteSocket.readable.getReader();

// 发送首帧数据
if (firstFrameData) {
await remoteWriter.write(encoder.encode(firstFrameData));
}

webSocket.send('CONNECTED');
pumpRemoteToWebSocket();
return;

} catch (err) {
// 清理失败的连接
try { remoteWriter?.releaseLock(); } catch {}
try { remoteReader?.releaseLock(); } catch {}
try { remoteSocket?.close(); } catch {}
remoteWriter = remoteReader = remoteSocket = null;

// 如果不是 CF 错误或已是最后尝试,抛出错误
if (!isCFError(err) || i === attempts.length - 1) {
throw err;
}
}
}
};

webSocket.addEventListener('message', async (event) => {
if (isClosed) return;

try {
const data = event.data;

if (typeof data === 'string') {
if (data.startsWith('CONNECT:')) {
const sep = data.indexOf('|', 8);
await connectToRemote(
data.substring(8, sep),
data.substring(sep + 1)
);
}
else if (data.startsWith('DATA:')) {
if (remoteWriter) {
await remoteWriter.write(encoder.encode(data.substring(5)));
}
}
else if (data === 'CLOSE') {
cleanup();
}
}
else if (data instanceof ArrayBuffer && remoteWriter) {
await remoteWriter.write(new Uint8Array(data));
}
} catch (err) {
try { webSocket.send('ERROR:' + err.message); } catch {}
cleanup();
}
});

webSocket.addEventListener('close', cleanup);
webSocket.addEventListener('error', cleanup);
}

function safeCloseWebSocket(ws) {
try {
if (ws.readyState === WS_READY_STATE_OPEN ||
ws.readyState === WS_READY_STATE_CLOSING) {
ws.close(1000, 'Server closed');
}
} catch {}
}

2.修改第13行设置token,双引号中间输入任意字符串。

软件下载

ECHWorkers

ECH域名:cloudflare-ech.com

自选反代IP

fofa官网

临时邮箱

搜索关键词:asn!="13335" && region="TW" && server=="cloudflare"

CloudflareSpeedTest 优选IP工具

地区码对照表 须要科学上网

DOH服务器

  • 阿里云(默认):dns.alidns.com/dns-query

  • 腾讯 DNSPod:doh.pub/dns-query

  • 360 安全 DNS: doh.360.cn/dns-query


【保姆级】0成本搭建个人专属高速网络通道!手机电脑通用,实测跑满千兆宽带!
https://www.202520.xyz/posts/5.html
作者
夜眠迟
发布于
2025年12月17日
许可协议