利用Cloudfare worker反代github

  1. 绑定你的域名到 cloudflare

  2. 创建一个 worker,并写入如下代码:

    js 复制代码
    // 反代目标网站.
    const upstream = 'github.com';
    
    // 反代目标网站的移动版.
    const upstream_mobile = 'github.com';
    
    // 访问区域黑名单(按需设置).
    const blocked_region = [''];
    
    // IP地址黑名单(按需设置).
    const blocked_ip_address = ['0.0.0.0', '127.0.0.1'];
    
    // 路径替换.
    const replace_dict = {
      '$upstream': '$custom_domain', // 将"$upstream"替换为"$custom_domain"
      '//github.com': '' // 移除路径中的"//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'); // 获取访问者的IP地址
      const user_agent = request.headers.get('user-agent'); // 获取访问者的User-Agent头部信息
    
      let response = null;
      let url = new URL(request.url);
      let url_host = url.host;
    
      if (url.protocol == 'http:') { // 如果请求协议是HTTP,则重定向到HTTPS
        url.protocol = 'https:';
        response = Response.redirect(url.href);
        return response;
      }
    
      if (await device_status(user_agent)) { // 判断是否为移动设备
        var upstream_domain = upstream;
      } else {
        var upstream_domain = upstream_mobile;
      }
    
      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 if (blocked_ip_address.includes(ip_address)){ // 检查IP地址是否在黑名单中
        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); // 设置请求头的Host字段为反代目标网站的域名
        new_request_headers.set('Referer', url.href); // 设置请求头的Referer字段为当前请求的URL
    
        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 && content_type.includes('text/html') && 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();
    
      for (let i in replace_dict) {
        let 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. 自定义域名,方便访问

相关推荐
西柚与蓝莓16 小时前
任务【浦语提示词工程实践】
github
Good_Starry1 天前
Git介绍--github/gitee/gitlab使用
git·gitee·gitlab·github
云端奇趣1 天前
探索 3 个有趣的 GitHub 学习资源库
经验分享·git·学习·github
运营黑客1 天前
发现一超级Prompt:让GPT-4o、Claude3.5性能再升级(附保姆级教程)
github
記億揺晃着的那天1 天前
Github优质项目推荐-第二期
github
Uncertainty!!1 天前
GitHub入门与实践
github
罗曼蒂克在消亡1 天前
github项目——gpt-pilot自动创建应用
gpt·github·github项目
篝火1 天前
MindSearch 部署到Github Codespace 和 Hugging Face Space
人工智能·python·github
无限大.2 天前
0基础学前端 day6 -- 搭建github pages静态网址
前端·github