利用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. 自定义域名,方便访问

相关推荐
墨理学AI7 小时前
GitHub 桌面版配置 |可视化界面进行上传到远程仓库 | gitLab 配置【把密码存在本地服务器】
gitlab·github·github 桌面版
AI理性派思考者14 小时前
【保姆教程】手把手教你在Linux系统搭建早期alpha项目cysic的验证者&证明者
后端·github·gpu
wy02_18 小时前
Linux下载RabbitMQ,并解决Github拒绝访问443的问题
linux·rabbitmq·github
Domain-zhuo19 小时前
Git常用命令
前端·git·gitee·github·gitea·gitcode
aPurpleBerry19 小时前
解决 fatal: detected dubious ownership in repository at ‘XXXX‘ 问题
github
vvw&1 天前
如何在 Ubuntu 22.04 上安装 Graylog 开源日志管理平台
linux·运维·服务器·ubuntu·开源·github·graylog
HelloGitHub1 天前
跟着 8.6k Star 的开源数据库,搞 RAG!
开源·github
sdaxue.com2 天前
帝国CMS:如何去掉帝国CMS登录界面的认证码登录
数据库·github·网站·帝国cms·认证码
m0_748247552 天前
github webhooks 实现网站自动更新
github
张国荣家的弟弟2 天前
【Yonghong 企业日常问题04】永洪BI可视化工具Linux部署全攻略(部署详解版)
linux·运维·github