本站承诺永不接任何虚假欺骗、联盟广告、弹窗广告、病毒广告、诱导充值等影响用户体验的广告,广告屏蔽插件会影响本站部分功能,还请不要屏蔽本站广告,感谢支持!

当前位置:首页 / 正文

2019-11-26 | 编程技术 | 11735 次阅读 | 等你评论 | 5 次点赞 | 繁体

介绍

WorkersProxy 是一个轻量级的 Javascript 应用程序,可从其他服务器作为客户端检索资源。

在 Cloudflare Workers 上进行部署时,您可以构建自定义的反向代理,而无需购买计算引擎和配置 Nginx 等 Web 服务器。

此外,由于您的应用程序将通过 Cloudflare 遍布 90 多个国家 / 地区的全球数据中心网络进行分发,因此将优化关键性能,例如延迟和可用性。

通过配置地理位置和 IP 地址过滤器,您可以根据其特定规定在特定国家或地区直接暂停反向代理服务。利用移动重定向器,您可以根据用户的设备分发各种网页

部署

导航到 Cloudflare Workers,注册或登录您的 Cloudflare 帐户,并为 worker 设置自定义子域,然后创建一个新的 Worker。

自定义 “index.js”,将代码粘贴到 Cloudflare 在线编辑器中以替换默认代码。

更改工作人员的名称,保存并部署它,并检查其性能是否满足您的需求。

绑定域名

检查您的域当前是否处于 Cloudflare 的保护之下。

导航到您的域的仪表板,选择 “工作人员” 页面,然后单击 “添加路线”。

键入 https://<;domain-name>/* 在 Route 选择之前创建的工人。

为您的自定义域添加 CNAME DNS 记录。具体而言,在 “名称” 字段中输入子域(或在根目录中为 “ @”),在 “目标” 字段中输入工作人员的二级域,然后将 “代理状态” 设置为 “代理”。

自定义 index.js

显然,在主 Javascript 文件的顶部定义了一些常量。

要自定义自己的 WorkersProxy 服务,您应根据自己的期望进行编辑。

// List of domains bind to your WorkersProxy.
const domain_list = ['https://google.error.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 = ['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');
    const http = "http://";
    const https = "https://";
    
    let response = null;
    let url = request.url;

    if (url.startsWith(http)) {
        url = url.replace(http, https);
        response = Response.redirect(url);
        return response;
    }

    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)
        let host_name = upstream_domain.replace(http, '')
        host_name = upstream_domain.replace(https, '')
        host_name = upstream_domain.replace('/', '')

        new_request_headers.set('Host', host_name)
        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
        })
    }
    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;
}

domain_list:主域名,可以是自己的域名,记得做好解析

upstream、upstream_mobile:反代的网址,两者保持一致即可除非该网站有移动端的域名

blocked_region:禁止访问的地区,记得去除'CN'

标签: javascriptgoogle

猜你喜欢
Lazysizes.js图片懒加载的使用
lazysizes 是一种快速(无垃圾),对 SEO 友好且可自动初始化的 lazyloader,用于图像(包括响应图像 picture/ srcset),iframe,脚本/小部件等。它还通过...
通用的检测到广告屏蔽插件进行弹窗提示实现方法
用的 js 方法来检测,按理说所有博客都能使用,就是在打开网页的时候进行一次判断。如果发现没有加载广告代码,就会出来一个弹窗来提示浏览者将本站加到广告拦截插件的白名单里面。别喷我,个人站长经营实...
javascript | 原生JS多语言切换简单实现
由于项目需要实现一个前端的多语言切换,不想因为一个简单的功能就引入 jQuery,所以经过 google 编程大法摸索出一个原生 JS 就可以实现的多语言前端切换的小例子,仅供参考。<bo...
教你轻松拥有无限个邮箱
这里说的无限邮箱,不是去无限注册邮箱。而是指你一个邮箱下有无限个子邮箱,或者说无限个影子邮箱。实现方法比较多,本文推荐两种。先说一下好处当你有了多个邮箱,作用很明显,比如:一个网站,轻松注册多个...
原生js实现ajax方法
由于不想多引入一个 jquery,百度了一个原生 js 实现 ajax 的方法(超简单),挺不错的,现在就分享给大家,也给大家做个参考。首先新建一个 js 文件:function ajax(){...
github 的黑夜模式小猫咪动画源码
github 上的小猫咪黑夜模式切换很可爱,想要~ 。于是花了点时间扒了下来放在了自己的博客上。秉着开源精神,将源码分享给大家。废话少说,上代码html:<!-- 暗黑模式 --> ...
原生js实现ajax方法
由于不想多引入一个 jquery,百度了一个原生 js 实现 ajax 的方法(超简单),挺不错的,现在就分享给大家,也给大家做个参考。 首先新建一个 js 文件: ``` function
像程序员一样安装程序:Chocolatey 初见
每次拿到一台新的电脑,快速安装上所有自己需要的程序是一件非常非常耗时间的事情。 如果去国内各大第三方下载站,或者电脑管家、百度的安装工具,它们很多都会把原生的安装包进行修改,加入自己的广告或其他
(首次提交评论需审核通过才会显示,请勿重复提交)