Skip to content

Cloudflare注册及使用

更新时间: 12/12/2024

简介

美国比较有名的 CDN 加速服务商,提供免费和付费的加速和网站保护服务

我们常说的 套个CF ,其实就是说的cloudflare

什么是CDN

CDN 的全称是 Content Delivery Network,即内容分发网络

  • 比方:北京到广东的快递包裹,时长要3天;但如果北京在广东有货物仓储,直接广东发货,时长就仅需1天

  • 作用:CDN就是这个作用,将我们的网站临时存储在服务器中,谁访问就分配距离他最近的节点连接,从而大大加快网页访问速度

另:常见的CDN服务商还有 又拍云七牛云腾讯云COS阿里云OSS

官网:https://www.cloudflare.com/zh-cn/

注册

官网注册 账号就行

说明

虽然有中国站点,但访问还是要 科学上网 ,否则无法跳转

使用

Cloudflare还可以创建 cloudflare page ,但体验上稍微差点,这里先不演示

域名解析

先自己 购买一个域名 或者 使用 ClouDNS的免费域名

腾讯云 演示,进入控制台 - 域名注册 - 我的域名

在 Cloudflare 主页 - 添加站点

输入你的域名,继续

方案这里下拉,选 Free 免费的,确认计划

开始扫描DNS记录

我只买了域名,没买服务器,就没解析过,所以没扫描到,点继续

这里需要我们更改成 Cloudflare 的DNS服务器

打开域名界面,勾选域名,修改DNS服务器

自定义DNS,分别复制 Cloudflare 提供的两个DNS,下一步

确认提交

域名页面显示:DNS 地址待修改

因为它推荐你用默认的,我们已经使用Cloudflare了,不用管

等待邮箱提示激活

成功后,域名前会显示对勾

CDN加速:网站访问

适用于服务器在国外,给网站套了cf,访问会有明显提升

服务器在国内可以用吗

可以,但没必要!国内访问已经很快了,没必要通过cloudflare

在 Cloudflare 主页点击你的域名

在DNS栏,添加记录

常用的解析

  • 类型:A
    • 名称:@ (一级域名,如:baidu.com)
      • iPv4地址:填服务器IP
    • 名称:www (二级域名,可自定义,如:www.baidu.com)
      • iPv4地址:填服务器IP
    • 名称:* (泛解析,不要轻易使用)
      • iPv4地址:填服务器IP

  • 类型:CNAME (别名解析)
    • 名称:@ (一级域名,如:yiov.top)
      • iPv4地址:其他域名 (比如:yiov.github.io)
    • 名称:nav (二级域名,可自定义,如:nav.yiov.top)
      • iPv4地址:其他域名 (比如:yiov.github.io)

说明:二级/三级域名,都可以随意添加,免费的

CDN加速:Github Pages 加速

之前写过,但访问效果平平,还不如直接用 Vercel

WARP科学上网 - Zero Trust

WARP是cloudflare公司推出的一款基于wireguard协议的VPN服务,但比传统的VPN更稳定更安全可靠

点击 Zero Trust

Cloudflare WARP 账户区别

账户分为3种:warp、warp+、zero trust

  • warp:免费版(普通账户),无限流量,拉新可获得Warp+流量,无法隐藏源IP

  • Warp+:付费订阅版,有限流量,可以隐藏源IP

  • Zero Trust:Team团队版,需自行注册Cloudflare ,无限流量,50人以内免费,可以隐藏源IP

输入一个团队名,自己取就行

然后选择免费 Free 的方案

Proceed to payment 继续支付

提示要添加信用卡,否则无法跳过,但是有办法

我们直接关闭网页!重新打开 仪表盘主页 就可以跳过了

重新进去后再次进入 Zero Trust

点击 My Team - Devices ,然而我的团队里没有添加设备的选项

我们可以通过 网页后退 或者 点其他地方 再返回,就能恢复

我就随便点了一下 Lists

返回 Devices ,就可以正常添加了 Connect a device

这里填写邮箱后缀!邮箱后缀名!不是填完整的邮箱

重要

由于我们是跳过了支付页,就无法进入后台,新增其他邮箱后缀了

本次填写后就无法修改,请确定要使用的邮箱类型

  • 谷歌邮箱后缀:@gmail.com,必须用谷歌邮箱注册方可加入团队

  • QQ邮箱后缀:@qq.com,必须用QQ邮箱注册方可加入团队

  • ... (以此类推)

注:非当前填写的邮箱类型,注册将无法接收到验证码!

然后要选择一个客户端,我就选 Windows 吧,必须要点一下!!!

不需要下载,等会我们统一使用其他客户端

接下来会跳出你的团队名,点一个 copy,必须要点一下!!!

团队名找回或修改

Zero Trust - Settings - Custom Pages - Team domain

最后下载根证书,点一下就行了,不用其他操作了

不管刚刚跳转的客户端是什么,都推荐使用 1.1.1.1

为什么使用1.1.1.1

它本是Cloudflared的DNS服务,通过全球的CDN提高访问网站时的速度

而后官方集成了WARP,推出了这款应用程序

官网:https://1.1.1.1/,网站打开需要 科学上网

下载完成点安装

关于手机端的使用

使用方式基本一致,是在搞不懂可以参照 WARP的使用教程

安装完成没有桌面快捷方式,可以在开始菜单中找到,打开后再桌面右下角有小图标

现在不能直接用,需要配置账户,我们点击小齿轮

偏好设置

账户

使用 Cloudflare Zero Trust 登录

团队名输入你直接创建的账户名

输入你的邮箱账号,填写验证码

没有验证码

请确保你的填写的邮箱账户,与之前写的邮箱后缀名一致!


如果你是添加了信用卡的付费用户,在Zero Trust/Settings/Warp Client/Device enrollment/Policies 中添加邮箱后缀

注册成功后,WARP会变为 Zero Trust 显示

打开开关,但是下面的提示仍然是不受保护

关闭后再次打开即可

访问 谷歌 自动给我跳转到了 谷歌香港,应该是使用的台湾或香港节点

最后 测一下速

或者使用 国内的 测速网,速度不快,延迟也高,只能说勉强能用

说明

  • 下载:900KB/s

  • 上传:747KB/s

  • 延迟:528ms

在 Zero Trust - 团队 - 用户列表也能看到加入的用户

针对网络延迟高,我们可以通过优选一下IP来解决

说明

这里的优选IP是 优选WARP ,不是 优选Cloudflare

开始前请先断开WARP以及所有VPN

下载解压 @甬哥WIN端warp自选IP-v23.11.15.zip

解压后运行 手动方式1:生成优选IP端口结果文件.bat

这里我们输入 1 ,回车

优选的结果自动生成了 result.csv 文件,按任意键退出

鼠标对着 result.csv 右键,用 记事本打开

点击运行 手动方式2:将IP端口复制到这里.bat

将筛选出来的IP和端口,填入bat命令行中,回车

没有效果?

手动方式2:将IP端口复制到这里.bat 复制到Cloudflare WARP文件夹中后运行

默认路径:C:\Program Files\Cloudflare\Cloudflare WARP

或者使用 自动方式:官方warp自动设置端点.bat


其他:

  • 桌面快捷方式查看:鼠标右键 - 属性 - 打开文件所在位置

  • 没有桌面快捷方式:开始 - 最近 Cloudflare WARP - 右键 更多 - 打开文件位置,鼠标右键 - 发送到 桌面快捷方式

重新打开WARP开关

再次 测速 ,会发现已经变的好多了

说明

上传下载没什么提升,但是延迟确实有降低

日常用基本满足

搭建节点

搭建Github镜像站

进入 Cloudfare仪表盘 点击 Workers 和 Pages - 创建Worker

名称随便,我这里就写成github,点 部署

成功后,我们的链接也有了,先点 编辑

这里的代码先 全部删掉 ,复制下面代码粘贴进去,部署

点我查看详细代码
js
// 你要镜像的网站.
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
}

点连接查看,是否成功

由于works域名国内无法访问,我们可以添加一个自己的域名

设置 - 触发器 - 添加自定义域

注意:你的 域名必须已经解析在Cloudflare

再次使用绑定的域名访问即可

关于缺点

无法登录账号 和 进入raw.githubusercontent.com 页面

其实就是利用了一个反代功能,理论上可以镜像所有网站

搭建vless节点

进入 Cloudfare仪表盘 点击 Workers 和 Pages - 创建Worker

Workers 和 Pages 有什么区别
  • Workers:仅修改 workws.js 代码即可,可选择是否开启tls

  • Pages:需要将 _workws.js 文件放入文件夹中上传,默认开启tls,不可关闭

名称随便,我这里就写成vless,点 部署

成功后,我们的链接也有了,先点 编辑

这里的代码先 全部删掉 ,去找搭建脚本替换上去

这里用 @甬哥的脚本:Cloudflare_vless_trojan 演示,进入文件夹 vless_workers_pages

其他大佬脚本

主要是甬哥的比较适合小白,而且更新比较频繁

点击 _worker.js

CTRL+A全选代码,复制

删除自带的原代码,将复制的代码粘贴到 Worker.js 中并部署

部署成功后,点击访问

就得到了这样一个页面

我们根据 @甬哥的文档 说明改一下uuid

在 workjs 项目中,设置 - 变量和机密 - 添加

类型就为文本,变量名称为 uuid ,值填入新的UUID即可

UUID获取方式

注意:不要有空格、字符、换行符等

另一个可选的 proxyip 变量 已经默认填好了,可以不用管

@3Kmfi6HP 大佬提供的proxyip:
md
cdn-all.xn--b6gac.eu.org

cdn.xn--b6gac.eu.org

cdn-b100.xn--b6gac.eu.org

edgetunnel.anycast.eu.org

cdn.anycast.eu.org

我们在网址后加 /你的uuid 回车进入节点页面

比如

网址:vless.你的用户名.workers.dev

访问:https://vless.你的用户名.workers.dev/uuid

节点有两个,一个是关闭了TLS加密,一个是启用了TLS加密,区别如下

类型HTTPHTTPS
节点vless+wsvless+ws+tls
端口80、8080、8880、2052、2082、2086、2095443、8843、2053、2083、2087、2096
TLS关闭开启
域名非必须提供必须提供
安全

没有域名,直接使用第一个关闭了TLS的;有域名的,看我步骤添加自定义域名

在当前Worker中,设置 - 域名和路由 - 添加

自定义域,填入你已解析在Cloudfare上的域名

这样就添加成功了

点击复制链接,Vless:// 开头的那一长串

使用任意一款支持Vless协议的 科学上网工具 从剪切板导入,比如 V2rayN

然后右键测速,真连接延迟,有数字就可以

延迟显示 -1ms

检查配置是否正确,或更换proxyIP后尝试

现在还是连不了,双击节点打开配置,右上角切换为Xray核心

再次尝试访问 谷歌 看看

说明

由于节点延迟感人,强烈建议 优选域名 或者 优选IP

优选域名

主要是对大型网站的服务器筛选,非常稳,但是速度不快

只能填在科学上网工具的 服务器地址

搭建节点补充:优选域名(windows端)

在节点上服务器地址,这个网址是什么

我们访问这个网址 VISA,点击小锁查看证书,发现是 Cloufare 颁发的

也就是利用了 Cloudfare 的CDN特性,来降低延迟

这里用 @甬哥的工具:CDN优选域名V23.8.18(电脑win64).exe 来筛选最优域名

开始前,请先断开所有代理!!!否则不准!!!

双击打开运行,耐心等待一会

跑完后会自动生成一个 CDNym.txt 文件

打开文件,复制延迟最低的网址

粘贴到代理软件,开启代理,测速真连接延迟明显降低

开启代理,通过访问 ip.gsipleak.netBrowserLeaks,IP是在一个范围内跳动,不是永久固定的

搭建节点补充:优选域名(iOS端)

iOS端可以使用 小火箭 或者 Karing

我用小火箭演示,复制节点打开小火箭添加

测一下速,有延迟显示即可,访问 谷歌 看看

国区AppStore下载 iSH Shell 并安装

安装 openssh curl bash 命令

sh
apk add openssh curl bash
卡住不动了?

点击 + z 键可退出,挂上梯子翻墙了再安装即可

也可以直接更换镜像

sh
sed -i 's/dl-cdn.alpinelinux.org/mirrors.tuna.tsinghua.edu.cn/g' /etc/apk/repositories

安装完成后,使用 @甬哥的脚本:优选CDN域名 ,命令如下

sh
curl -sSL https://gitlab.com/rwkgyg/CFwarp/raw/main/point/CFcdnym.sh -o CFcdnym.sh && chmod +x CFcdnym.sh && bash CFcdnym.sh

耐心等待一会,由于苹果的特殊性,排序是乱的,需要我们自行找到延迟最低的域名网址

点击节点旁的 i 进入编辑,替换地址出的网址,再次测速延迟明显降低

开启代理,通过访问 ip.gsipleak.netBrowserLeaks,IP是在一个范围内跳动,不是永久固定的

搭建节点补充:优选域名(Android端)

安卓端可以使用 NekoBoxV2ray

我用 NekoBox 演示,复制搭建好的节点,从剪切板导入

测一下速,连接测试 - URL Test

下载 Termux 并安装

下载哪一个

作者的文件名太长了,电脑端能看清

按顺序分别适用:手机64位、手机32位、手机64/32通用、平板32位、平板64位

首次使用需要更新一下,后面使用就不用了

有提示[Y/n],输入 y,提示 Defult 直接回车

sh
pkg update && pkg install curl
卡住不动了?

点击 + z 键可退出,挂上梯子翻墙了再安装即可

也可以直接更换镜像

sh
sed -i 's/dl-cdn.alpinelinux.org/mirrors.tuna.tsinghua.edu.cn/g' /etc/apk/repositories

安装完成后,使用 @甬哥的脚本:优选CDN域名 ,命令如下

耐心等待一会,在结果中复制延迟最低的域名网址

sh
curl -sSL https://gitlab.com/rwkgyg/CFwarp/raw/main/point/CFcdnym.sh -o CFcdnym.sh && chmod +x CFcdnym.sh && bash CFcdnym.sh

打开 NekoBox 点节点编辑 - 服务器,替换成优选的域名

再次测速发现,节点延迟已经降低了

开启代理,通过访问 ip.gsipleak.netBrowserLeaks,IP是在一个范围内跳动,不是永久固定的

优选IP

主要是对所有cf的服务器筛选,速度快,但是不一定稳

既可以填在科学上网工具的 服务器地址 中,也可以填在 work.js 的 proxyIPs

搭建节点补充:优选官方IP(windows端)

下载 甬哥的 CF优选官方IP(电脑版).zip ,解压后双击打开 CF官方IP优先工具(电脑版).exe

说明

不太推荐 优选反代IP ,因为这些都是被大佬扫出来的,容易失效

这里我选 1 IPv4,端口 我选 2095

如何查询IPv4还是IPv6

IPv6测试:https://www.test-ipv6.com/

IP查询:https://ipw.cn/

端口的使用区别
  • 搭建的节点未开启TLS,用80系列端口

  • 搭建的节点已开启TLS,用443系列端口

类型HTTPHTTPS
节点vless+wsvless+ws+tls
端口80、8080、8880、2052、2082、2086、2095443、8843、2053、2083、2087、2096
TLS关闭开启
域名非必须提供必须提供

脚本会自动选出最优的5个IP,复制第一个

替换到节点 服务器地址端口 中,确定

测试一下延迟

开启代理,通过访问 ip.gsipleak.netBrowserLeaks,IP是在一个范围内跳动,不是永久固定的

搭建节点补充:优选官方IP(iOS端)

经过测试,iOS端使用 iSH Shell 跑代码会崩溃

所以,要么使用其他客户端优选后,复制过来用

要么直接用 优选域名

搭建节点补充:优选官方IP(Android端)

安卓端可以使用 NekoBoxV2ray

我用 NekoBox 演示,复制搭建好的节点,从剪切板导入

测一下速,连接测试 - URL Test

下载 Termux 并安装

下载哪一个

作者的文件名太长了,电脑端能看清

按顺序分别适用:手机64位、手机32位、手机64/32通用、平板32位、平板64位

首次使用需要更新一下,后面使用就不用了

有提示[Y/n],输入 y,提示 Defult 直接回车

sh
pkg update && pkg install curl
卡住不动了?

点击 + z 键可退出,挂上梯子翻墙了再安装即可

也可以直接更换镜像

sh
sed -i 's/dl-cdn.alpinelinux.org/mirrors.tuna.tsinghua.edu.cn/g' /etc/apk/repositories

安装完成后,使用 @甬哥的脚本:优选官方IP ,命令如下

sh
curl -sSL https://gitlab.com/rwkgyg/CFwarp/raw/main/point/cfip.sh -o cfip.sh && chmod +x cfip.sh && bash cfip.sh

我们选 1 优选官方IP,端口我用的 8880

官方IP和反代IP的区别
  • 官方IP:稳定,但速度一般

  • 反代IP:速度快,但不太稳定,容易失效

端口的使用区别
  • 搭建的节点未开启TLS,用80系列端口

  • 搭建的节点已开启TLS,用443系列端口

类型HTTPHTTPS
节点vless+wsvless+ws+tls
端口80、8080、8880、2052、2082、2086、2095443、8843、2053、2083、2087、2096
TLS关闭开启
域名非必须提供必须提供

耐心等待一会,在结果中复制延迟最低的域名网址

打开 NekoBox 点节点编辑 - 服务器,替换成优选的域名

再次测速发现,节点延迟已经降低了

开启代理,通过访问 ip.gsipleak.netBrowserLeaks,IP是在一个范围内跳动,不是永久固定的

特别鸣谢