全球主机交流论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

IP归属甄别会员请立即修改密码
查看: 2758|回复: 2
打印 上一主题 下一主题

简单三步利用cf works反代api.cloudflare.com

[复制链接]
跳转到指定楼层
1#
发表于 2023-6-20 01:37:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 kimigao 于 2023-6-20 01:41 编辑

接上贴:api.cloudflare.com被墙了,有人宣布对此负责吗

如果你也受api.cloudflare.com假墙影响,可以利用cf Worker反代cf Api

原出处:https://www.nadph.net/archives/145

1.创建一个Worker,部署后编辑代码

2.贴上代码
  1. // Website you intended to retrieve for users.
  2. const upstream = api.cloudflare.com'

  3. // Custom pathname for the upstream website.
  4. const upstream_path = '/'

  5. // Website you intended to retrieve for users using mobile devices.
  6. const upstream_mobile = upstream

  7. // Countries and regions where you wish to suspend your service.
  8. const blocked_region = []

  9. // IP addresses which you wish to block from using your service.
  10. const blocked_ip_address = ['0.0.0.0', '127.0.0.1']

  11. // Whether to use HTTPS protocol for upstream address.
  12. const https = true

  13. // Whether to disable cache.
  14. const disable_cache = false

  15. // Replace texts.
  16. const replace_dict = {
  17.     '$upstream': '$custom_domain',
  18. }

  19. addEventListener('fetch', event => {
  20.     event.respondWith(fetchAndApply(event.request));
  21. })

  22. async function fetchAndApply(request) {
  23.     const region = request.headers.get('cf-ipcountry').toUpperCase();
  24.     const ip_address = request.headers.get('cf-connecting-ip');
  25.     const user_agent = request.headers.get('user-agent');

  26.     let response = null;
  27.     let url = new URL(request.url);
  28.     let url_hostname = url.hostname;

  29.     if (https == true) {
  30.         url.protocol = 'https:';
  31.     } else {
  32.         url.protocol = 'http:';
  33.     }

  34.     if (await device_status(user_agent)) {
  35.         var upstream_domain = upstream;
  36.     } else {
  37.         var upstream_domain = upstream_mobile;
  38.     }

  39.     url.host = upstream_domain;
  40.     if (url.pathname == '/') {
  41.         url.pathname = upstream_path;
  42.     } else {
  43.         url.pathname = upstream_path + url.pathname;
  44.     }

  45.     if (blocked_region.includes(region)) {
  46.         response = new Response('Access denied: WorkersProxy is not available in your region yet.', {
  47.             status: 403
  48.         });
  49.     } else if (blocked_ip_address.includes(ip_address)) {
  50.         response = new Response('Access denied: Your IP address is blocked by WorkersProxy.', {
  51.             status: 403
  52.         });
  53.     } else {
  54.         let method = request.method;
  55.         let request_headers = request.headers;
  56.         let new_request_headers = new Headers(request_headers);

  57.         new_request_headers.set('Host', upstream_domain);
  58.         new_request_headers.set('Referer', url.protocol + '//' + url_hostname);

  59.         let original_response = await fetch(url.href, {
  60.             method: method,
  61.             headers: new_request_headers,
  62.             body: request.body
  63.         })

  64.         connection_upgrade = new_request_headers.get("Upgrade");
  65.         if (connection_upgrade && connection_upgrade.toLowerCase() == "websocket") {
  66.             return original_response;
  67.         }

  68.         let original_response_clone = original_response.clone();
  69.         let original_text = null;
  70.         let response_headers = original_response.headers;
  71.         let new_response_headers = new Headers(response_headers);
  72.         let status = original_response.status;
  73.                
  74.                 if (disable_cache) {
  75.                         new_response_headers.set('Cache-Control', 'no-store');
  76.             }

  77.         new_response_headers.set('access-control-allow-origin', '*');
  78.         new_response_headers.set('access-control-allow-credentials', true);
  79.         new_response_headers.delete('content-security-policy');
  80.         new_response_headers.delete('content-security-policy-report-only');
  81.         new_response_headers.delete('clear-site-data');
  82.                
  83.                 if (new_response_headers.get("x-pjax-url")) {
  84.             new_response_headers.set("x-pjax-url", response_headers.get("x-pjax-url").replace("//" + upstream_domain, "//" + url_hostname));
  85.         }
  86.                
  87.         const content_type = new_response_headers.get('content-type');
  88.         if (content_type != null && content_type.includes('text/html') && content_type.includes('UTF-8')) {
  89.             original_text = await replace_response_text(original_response_clone, upstream_domain, url_hostname);
  90.         } else {
  91.             original_text = original_response_clone.body
  92.         }
  93.                
  94.         response = new Response(original_text, {
  95.             status,
  96.             headers: new_response_headers
  97.         })
  98.     }
  99.     return response;
  100. }

  101. async function replace_response_text(response, upstream_domain, host_name) {
  102.     let text = await response.text()

  103.     var i, j;
  104.     for (i in replace_dict) {
  105.         j = replace_dict[i]
  106.         if (i == '$upstream') {
  107.             i = upstream_domain
  108.         } else if (i == '$custom_domain') {
  109.             i = host_name
  110.         }

  111.         if (j == '$upstream') {
  112.             j = upstream_domain
  113.         } else if (j == '$custom_domain') {
  114.             j = host_name
  115.         }

  116.         let re = new RegExp(i, 'g')
  117.         text = text.replace(re, j);
  118.     }
  119.     return text;
  120. }


  121. async function device_status(user_agent_info) {
  122.     var agents = ["Android", "iPhone", "SymbianOS", "Windows Phone", "iPad", "iPod"];
  123.     var flag = true;
  124.     for (var v = 0; v < agents.length; v++) {
  125.         if (user_agent_info.indexOf(agents[v]) > 0) {
  126.             flag = false;
  127.             break;
  128.         }
  129.     }
  130.     return flag;
  131. }
复制代码


3.绑定自己的域名
因Worker的域名也是被墙的,所以我们需要用自己的域名,在 Worker 的管理界面中,点击 “Custom Domians” 中的 “Add Custom Domain” 按钮以绑定域名,至此成功。
2#
发表于 2023-6-20 06:29:14 来自手机 | 只看该作者
一个cf帐号能开几个works?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|全球主机交流论坛

GMT+8, 2026-1-12 05:58 , Processed in 0.058688 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表