利用github上分享的代码搭建自己的谷歌镜像分分钟

已收录   阅读次数: 4,388
2019-09-2610:00:37 2
摘要

伯衡君之前介绍的一个网站就是利用该项目来搭建的,看起来高大上,其实操作很简单,简单到令人发指,站长亲自测试,真实有效,so easy!于是有了今天这篇文章……

分享至:
利用github上分享的代码搭建自己的谷歌镜像分分钟

开篇寄语

伯衡君之前介绍的一个网站就是利用该项目来搭建的,看起来高大上,其实操作很简单,简单到令人发指,站长亲自测试,真实有效,so easy!于是有了今天这篇文章。

项目介绍

github项目地址:https://github.com/Siujoeng-Lau/WorkersProxy

作者搭建的事例:https://cdn.reverse-proxy.live

WorkersProxy是一个轻量级的Javascript应用程序,可从其他服务器作为客户端检索资源。
在Cloudflare Workers(这是用于构建无服务器应用程序的有影响力的平台)上进行部署时,您可以构建自定义的反向代理,而无需购买计算引擎和配置Nginx等Web服务器。
此外,由于您的应用程序将通过Cloudflare遍布90多个国家/地区的全球数据中心网络进行分发,因此将优化关键性能,例如延迟和可用性。
通过配置地理位置和IP地址过滤器,您可以根据其特定规定在特定国家或地区直接暂停反向代理服务。利用移动重定向器,您可以根据用户的设备分发各种网页。

实现方法

利用github上分享的代码搭建自己的谷歌镜像分分钟
  • 注册,登陆,Start building,取一个子域名,Create a Worker
利用github上分享的代码搭建自己的谷歌镜像分分钟
  • 清空左侧默认代码区,复制下方代码到左侧代码框,save and display。如果正常,右侧就会显示页面了,代码如下,按照效果图稍微修改代码。
// List of domains bind to your WorkersProxy.
const domain_list = ['https://cdn.reverse-proxy.live/', 'https://google.xasiimov.workers.dev/']

// Website you intended to retrieve for users.
const upstream = 'https://www.google.com/'

// Website you intended to retrieve for users using mobile devices.
const upstream_mobile = 'https://www.google.com/'

// Countries and regions where you wish to suspend your service.
const blocked_region = ['CN', 'KP', 'SY', 'PK', 'CU']

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

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 = request.url;

    if (await device_status(user_agent)){
        upstream_domain = upstream
    } else {
        upstream_domain = upstream_mobile
    }

    for(let domain of domain_list) {
        url = url.replace(domain, 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)){
        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('origin', upstream_domain)
        new_request_headers.set('referer', upstream_domain)

        origin_response = await fetch(url, {
            method: method,
            headers: new_request_headers
        })
        
        let response_body = origin_response.body
        let response_headers = origin_response.headers
        let new_response_headers = new Headers(response_headers)
        let status = origin_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')

        response = new Response(response_body, {
            status,
            headers: response_headers
        })
        response = origin_response
    }
    return response;
}

async function device_status (userAgentInfo) {
    var Agents = ["Android", "iPhone", "SymbianOS", "Windows Phone", "iPad", "iPod"];
    var flag = true;
    for (var v = 0; v < Agents.length; v++) {
        if (userAgentInfo.indexOf(Agents[v]) > 0) {
            flag = false;
            break;
        }
    }
    return flag;
}
  • 左上角修改一下名称,修改一下代理网站,把大佬源码里的,“CN”删除。在const upstream = 'https://www.google.com/',可以添加多个代理地址,比如维基百科的等等。
  • 之后把右侧的网址复制浏览器,收藏下来,以后就可以使用了。免费版每天有10万个调用限制,如果自己用怎么着都够用了。
  • 我的微信
  • 微信扫一扫加好友
  • weinxin
  • 我的微信公众号
  • 扫描关注公众号
  • weinxin

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:2   其中:访客  0   博主  0

    • avatar Leo 0

      提示"Error 523",图示显示 Host Error,是不是被墙了?

        • avatar 伯衡君 Admin

          @Leo 尝试更换一下网络,我测试了一下,应该没有问题的。