Workers and Pages搭建各种项目(更新中》》》)

今天依旧更新一下关于我们赛博大善人的教程。

首先,Workers是Cloud flare免费提供的一项无服务器部署JavaScript代码到CF的边缘网络上的技术,免费版每天限制100k个请求(10万个),应该是够用了。

准备步骤:一枚CF和Github账号,一个能绑定在CF的域名,一个聪明的大脑,还有你勤劳的小手

一.使用CF Pages搭建Vless节点

1.登录进CF仪表盘后,右上角Language更改语言为简体中文后点击右侧的“Workers and Pages”,点击创建

2选Pages,上传资产

3.命名一下,创建项目,把这个包传上去,上传完成后点击部署站点,https://tutt.lanzouh.com/iNuzw227k25e  无密码

4.点击自定义域,设置一下域名,点击设置,环境变量,在制作那里添加变量

5.变量名称为UUID(大写),值的话可以在这个网站里生成:https://1024tools.com/uuid
默认生成了5个随便找一个复制就好,填进去,保存

6.点击部署,创建新部署,再把那个文件重新传一次就好

7.点击你刚才给Worker绑定的域名,加上/你设置的UUID即可,复制节点配置,添加到V2rayNG里,右键编辑服务器,
地址可以替换,我这里贴两个:www.gov.se,www.visa.com.sg,198.41.221.170,端口为443即可

二.使用Cloudflare和Telegraph搭建图床

1.Fork Telegraph-Image 仓库
访问 Telegraph-Image 仓库地址(https://github.com/cf-pages/Telegraph-Image),fork 到个人仓库:

2.同样点击右侧的“Workers and Pages”,点击创建,选Pages,连接到Git,绑定账号后选择相应仓库开始安装

3.安装完成后同样点击自定义域,设置一下域名,绑定好以后就可以用这个地址访问了,可以测试一下图片上传

4.配置高级点的功能
4-1.开启图片管理后台
Telegraph-Image 的图片管理功能默认是关闭的,我们需要绑定 KV 命名空间才能使用。

首先,依次点击 Workers 和 Pages , KV , 创建命名空间,添加一个名为image-hosting的命名空间

然后,依次点击 Workers 和 Pages,你刚才创建的那个Pages,设置,函数,绑定刚刚创建的命名空间image-hosting
变量名称设置为img_url,KV 命名空间设置为image-hosting,回到部署页面重试部署即可

4-2.后台登录验证:
要开启它,需要新增BASIC_USER(管理员登录名称)和BASIC_PASS(登录密码)环境变量,在你自定义的域名后面加上/admin即可访问。

三.使用Workers搭建Google镜像站

1.点击Workers和Pagers,创建,选Worker,创建一个Worker,命名一下,点击部署

2.部署完成后点击编辑代码,删掉原来的代码,粘贴下面的:
// 反代目标网站
const upstream = ‘ipv6.google.com.hk’
const upstream_v4 = ‘www.google.com.hk

// 访问区域黑名单(按需设置).
const blocked_region = [‘TK’]

//资源重定向
const replace_dict = {
$upstream: ‘$custom_domain’,
www.google.com/‘: ‘tu.tuji.cloudns.be/‘, //填入你的子域名(你之后要自定义的那个域名,不是CF默认的)
‘gstatic.com’: ‘gstatic.cn’,
‘ajax.googleapis.com’: ‘ajax.lug.ustc.edu.cn’,
‘fonts.googleapis.com’: ‘fonts.googleapis.cn’,
‘themes.googleusercontent.com’: ‘google-themes.lug.ustc.edu.cn’,
www.gravatar.com/avatar‘: ‘dn-qiniu-avatar.qbox.me/avatar’,
www.google.co.jp‘: ‘$custom_domain’,
www.google.com.sg‘: ‘$custom_domain’,
‘books.google.com.hk’: ‘$custom_domain’,
‘books.google.co.jp’: ‘$custom_domain’,
‘books.google.com.sg’: ‘$custom_domain’,
‘maps.google.com.hk’: ‘$custom_domain’,
‘maps.google.co.jp’: ‘$custom_domain’,
‘maps.google.com.sg’: ‘$custom_domain’,
‘maps.google.com’: ‘$custom_domain’,
‘books.google.com’: ‘$custom_domain’,
}

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_host = url.host

if (url.protocol == ‘http:’) {
url.protocol = ‘https:’
response = Response.redirect(url.href)
return response
}

//检查是否为图片搜索
var key = url.href
var ikey1 = ‘tbm=isch’
var ikey2 = ‘/img’
if ((key.search(ikey1) == -1) && (key.search(ikey2) == -1)) {
var upstream_domain = upstream
} else {
var upstream_domain = upstream_v4
}

url.host = upstream_domain

if (blocked_region.includes(region)) {
response = new Response(
‘Access denied: WorkersProxy is not available in your region yet.’,
{
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.href)

let original_response = await fetch(url.href, {
  method: method,
  headers: new_request_headers,
})

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

new_response_headers.set('cache-control', 'public, max-age=14400')
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')

const content_type = new_response_headers.get('content-type')
if (content_type.includes('text/html') && content_type.includes('UTF-8')) {
  // && content_type.includes('UTF-8')
  original_text = await replace_response_text(
    original_response_clone,
    upstream_domain,
    url_host
  )
} 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
}

注意:记得把 ‘www.google.com/‘: ‘tu.tuji.cloudns.be/‘, 此处的tu.tuji.cloudns.be替换为你的子域名(你之后要自定义的那个域名,不是CF默认的)

3.回到设置,触发器,绑定自定义域名,,等待DNS解析生效后即可访问

四.使用Workers镜像Github

1.点击Workers和Pagers,创建,选Worker,创建一个Worker,命名一下,点击部署

2.部署完成后点击编辑代码,删掉原来的代码,粘贴下面的:
// 你要镜像的网站.
const upstream = ‘github.com’

// 镜像网站的目录,比如你想镜像某个网站的二级目录则填写二级目录的目录名,镜像 google 用不到,默认即可.
const upstream_path = ‘/‘

// 镜像站是否有手机访问专用网址,没有则填一样的.
const upstream_mobile = ‘github.com’

// 屏蔽国家和地区.
const blocked_region = [‘KP’, ‘SY’, ‘PK’, ‘CU’]

// 屏蔽 IP 地址.
const blocked_ip_address = [‘0.0.0.0’, ‘127.0.0.1’]

// 镜像站是否开启 HTTPS.
const https = true

// 文本替换.
const replace_dict = {‘$upstream’: ‘$custom_domain’, ‘//github.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', url.hostname)
new_request_headers.set('Referer', url.hostname)

let original_response = await fetch(url.href, {
        method: method,
        headers: new_request_headers
})

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

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')

const content_type = new_response_headers.get('content-type')
if (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
}

3.回到设置,触发器,绑定自定义域名,,等待DNS解析生效后即可访问
注意!如果是使用CloudNS提供的免费域名,不要用来绑定类似于Github这种有关人家版权的网站,会被封号!这是我亲身试验过的!

待更新》》》


Workers and Pages搭建各种项目(更新中》》》)
http://example.com/2024/06/15/CF Worker搭建各种项目/
作者
图酱的老粉
发布于
2024年6月15日
更新于
2024年6月19日
许可协议