简单三步利用Cloudflare works反代cfapi

41次阅读

共计 4584 个字符,预计需要花费 12 分钟才能阅读完成。

内容最后由 kimigao 于 2023-6-20 01:37 编辑 接上贴:https://369369.xyz/host/topic/1180710.html 如果你也受 api.cloudflare.com 假墙影响,可以利用 Cloudflare Worker 反代 Cloudflare Api 原出处:https://www.nadph.net/archives/1451。创建一个 Worker,部署后编辑代码 2。贴上代码 // Website you intended to retrieve for users.const upstream = api.cloudflare.com\’// Custom pathname for the upstream website.const upstream_path = \’/\’// Website you intended to retrieve for users using mobile devices.const upstream_mobile = upstream// Countries and regions where you wish to suspend your service.const blocked_region = []// IP addresses which you wish to block from using your service.const blocked_ip_address = [\’0.0.0.0\’, \’127.0.0.1\’]// Whether to use HTTPS protocol for upstream address.const https = true// Whether to disable cache.const disable_cache = false// Replace texts.const replace_dict = {    \’$upstream\’: \’$custom_domain\’,}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 = new URL(request.url);    let url_hostname = url.hostname;    if (https == true) {        url.protocol = \’https:\’;   } else {        url.protocol = \’http:\’;   }    if (await device_status(user_agent)) {        var upstream_domain = upstream;   } else {        var upstream_domain = upstream_mobile;   }    url.host = upstream_domain;    if (url.pathname == \’/\’) {        url.pathname = upstream_path;   } else {        url.pathname = upstream_path + url.pathname;   }    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(\’Host\’, upstream_domain);        new_request_headers.set(\’Referer\’, url.protocol + \’//\’ + url_hostname);        let original_response = await fetch(url.href, {            method: method,            headers: new_request_headers,            body: request.body        })        connection_upgrade = new_request_headers.get("Upgrade");        if (connection_upgrade && connection_upgrade.toLowerCase() == "websocket") {            return original_response;        }        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;                if (disable_cache) {                        new_response_headers.set(\’Cache-Control\’, \’no-store\’);            }        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\’);                if (new_response_headers.get("x-pjax-url")) {            new_response_headers.set("x-pjax-url", response_headers.get("x-pjax-url").replace("//" + upstream_domain, "//" + url_hostname));        }        const content_type = new_response_headers.get(\’content-type\’);        if (content_type != null && content_type.includes(\’text/html\’) && content_type.includes(\’UTF-8\’)) {            original_text = await replace_response_text(original_response_clone, upstream_domain, url_hostname);        } 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()    var i, j;    for (i in replace_dict) {        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。绑定自己的域名因 Worker 的域名也是被墙的,所以我们需要用自己的域名,在 Worker 的管理界面中,点击“Custom Domians”中的“Add Custom Domain”按钮以绑定域名,至此成功。

正文完
 0