富强、民主、文明、和谐,自由、平等、公正、法治,爱国、敬业、诚信、友善,全面小康!

527 阅读3分钟

授人以鱼不如授人以渔 今天我要教大家的是利用CloudFlare 源码和原理皆来自于https://github.com/EtherDream/jsproxy/tree/master/cf-worker 因为目前国内各种工具数不胜数,质量参差不齐。使用这个方法可以从根本上解决隐私问题!而且操作简单!

第一步,登录注册CloudFlare账号 workers.cloudflare.com 注册过程在这里略过不做讲解!重要的是这个方法完全免费! 注册好账号之后进入页面,也是点击左上角 CloudFlare标志

然后选择workers

再点击创建

选中左侧编辑栏所有内容,全部删除。

打开 raw.githubusercontent.com/EtherDream/… 复制页面里的所有内容!

复制到workers页面左侧编辑栏 然后点击保存

URL右侧的保存也点击一次。

复制这个url 到浏览器打开

也可以点击左上角回到首页 再点击右侧workers

就可以看到刚才创建的项目了。点击分享标志会自动打开!这时候你已经成功的可以出国了!

如图,你现在就已经靠自己的操作复制成功的上路了!

当然,这个教程不止这些!后面才是重点。

经过测试youtube看视频的速度有时候会很不理想。 所以还有一种方法可以让你寻找一些免费的节点 回到最开始的地方 打开谷歌搜索

怎么样,是不是简单了许多

把东西直接放进来,你们复制一下就OK

'use strict'

/**

const JS_VER = 10 const MAX_RETRY = 1

/** @type {RequestInit} / const PREFLIGHT_INIT = { status: 204, headers: new Headers({ 'access-control-allow-origin': '', 'access-control-allow-methods': 'GET,POST,PUT,PATCH,TRACE,DELETE,HEAD,OPTIONS', 'access-control-max-age': '1728000', }), }

/**

  • @param {any} body
  • @param {number} status
  • @param {Object<string, string>} headers / function makeRes(body, status = 200, headers = {}) { headers['--ver'] = JS_VER headers['access-control-allow-origin'] = '' return new Response(body, {status, headers}) }

/**

  • @param {string} urlStr */ function newUrl(urlStr) { try { return new URL(urlStr) } catch (err) { return null } }

addEventListener('fetch', e => { const ret = fetchHandler(e) .catch(err => makeRes('cfworker error:\n' + err.stack, 502)) e.respondWith(ret) })

/**

  • @param {FetchEvent} e */ async function fetchHandler(e) { const req = e.request const urlStr = req.url const urlObj = new URL(urlStr) const path = urlObj.href.substr(urlObj.origin.length)

    if (urlObj.protocol === 'http:') { urlObj.protocol = 'https:' return makeRes('', 301, { 'strict-transport-security': 'max-age=99999999; includeSubDomains; preload', 'location': urlObj.href, }) }

    if (path.startsWith('/http/')) { return httpHandler(req, path.substr(6)) }

    switch (path) { case '/http': return makeRes('请更新 cfworker 到最新版本!') case '/ws': return makeRes('not support', 400) case '/works': return makeRes('it works') default: // static files return fetch(ASSET_URL + path) } }

/**

  • @param {Request} req

  • @param {string} pathname */ function httpHandler(req, pathname) { const reqHdrRaw = req.headers if (reqHdrRaw.has('x-jsproxy')) { return Response.error() }

    // preflight if (req.method === 'OPTIONS' && reqHdrRaw.has('access-control-request-headers') ) { return new Response(null, PREFLIGHT_INIT) }

    let acehOld = false let rawSvr = '' let rawLen = '' let rawEtag = ''

    const reqHdrNew = new Headers(reqHdrRaw) reqHdrNew.set('x-jsproxy', '1')

    // 此处逻辑和 http-dec-req-hdr.lua 大致相同 // github.com/EtherDream/… const refer = reqHdrNew.get('referer') const query = refer.substr(refer.indexOf('?') + 1) if (!query) { return makeRes('missing params', 403) } const param = new URLSearchParams(query)

    for (const [k, v] of Object.entries(param)) { if (k.substr(0, 2) === '--') { // 系统信息 switch (k.substr(2)) { case 'aceh': acehOld = true break case 'raw-info': [rawSvr, rawLen, rawEtag] = v.split('|') break } } else { // 还原 HTTP 请求头 if (v) { reqHdrNew.set(k, v) } else { reqHdrNew.delete(k) } } } if (!param.has('referer')) { reqHdrNew.delete('referer') }

    // cfworker 会把路径中的 // 合并成 / const urlStr = pathname.replace(/^(https?):/+/, '$1://') const urlObj = newUrl(urlStr) if (!urlObj) { return makeRes('invalid proxy url: ' + urlStr, 403) }

    /** @type {RequestInit} */ const reqInit = { method: req.method, headers: reqHdrNew, redirect: 'manual', } if (req.method === 'POST') { reqInit.body = req.body } return proxy(urlObj, reqInit, acehOld, rawLen, 0) }

/** *

  • @param {URL} urlObj

  • @param {RequestInit} reqInit

  • @param {number} retryTimes */ async function proxy(urlObj, reqInit, acehOld, rawLen, retryTimes) { const res = await fetch(urlObj.href, reqInit) const resHdrOld = res.headers const resHdrNew = new Headers(resHdrOld)

    let expose = '*'

    for (const [k, v] of resHdrOld.entries()) { if (k === 'access-control-allow-origin' || k === 'access-control-expose-headers' || k === 'location' || k === 'set-cookie' ) { const x = '--' + k resHdrNew.set(x, v) if (acehOld) { expose = expose + ',' + x } resHdrNew.delete(k) } else if (acehOld && k !== 'cache-control' && k !== 'content-language' && k !== 'content-type' && k !== 'expires' && k !== 'last-modified' && k !== 'pragma' ) { expose = expose + ',' + k } }

    if (acehOld) { expose = expose + ',--s' resHdrNew.set('--t', '1') }

    // verify if (rawLen) { const newLen = resHdrOld.get('content-length') || '' const badLen = (rawLen !== newLen)

    if (badLen) { if (retryTimes < MAX_RETRY) { urlObj = await parseYtVideoRedir(urlObj, newLen, res) if (urlObj) { return proxy(urlObj, reqInit, acehOld, rawLen, retryTimes + 1) } } return makeRes(res.body, 400, { '--error': bad len: ${newLen}, except: ${rawLen}, 'access-control-expose-headers': '--error', }) }

    if (retryTimes > 1) { resHdrNew.set('--retry', retryTimes) } }

    let status = res.status

    resHdrNew.set('access-control-expose-headers', expose) resHdrNew.set('access-control-allow-origin', '*') resHdrNew.set('--s', status) resHdrNew.set('--ver', JS_VER)

    resHdrNew.delete('content-security-policy') resHdrNew.delete('content-security-policy-report-only') resHdrNew.delete('clear-site-data')

    if (status === 301 || status === 302 || status === 303 || status === 307 || status === 308 ) { status = status + 10 }

    return new Response(res.body, { status, headers: resHdrNew, }) }

/**

  • @param {URL} urlObj */ function isYtUrl(urlObj) { return ( urlObj.host.endsWith('.googlevideo.com') && urlObj.pathname.startsWith('/videoplayback') ) }

/**

  • @param {URL} urlObj
  • @param {number} newLen
  • @param {Response} res */ async function parseYtVideoRedir(urlObj, newLen, res) { if (newLen > 2000) { return null } if (!isYtUrl(urlObj)) { return null } try { const data = await res.text() urlObj = new URL(data) } catch (err) { return null } if (!isYtUrl(urlObj)) { return null } return urlObj }