[网络技巧] 利用CloudFlare Worker 免费部署 JSProxy 服务
作者:CC下载站 日期:2019-10-29 03:15:46 浏览:2364 分类:web
本文来自@Dreamy.WJY投稿!博主编辑部分内容!
JSProxy 一个基于浏览器端 JS 实现的在线代理,这里不多介绍!
本文主要介绍一下利用CloudFlare Worker
来搭建一个JSProxy服务。
CloudFlare Worker
是 CloudFlare 的边缘计算服务。开发者可通过 JavaScript 对 CDN 进行编程,从而能灵活处理 HTTP 请求。这使得很多任务可在 CDN 上完成,无需自己的服务器参与。
CFW免费服务,支持每天10 万次免费请求!基本也够用了!
项目介绍
项目地址:https://github.com/EtherDream/jsproxy
准备工作
Cloudflare 账号一个
使用教程
1)打开 https://workers.cloudflare.com,登陆上你的 Cloudflare 账号激活 Workers 服务
然后创建一个 Workers【Create a Worker】
2)修改一下子域名,创建出来的域名格式 自定义的内容.Cloudflare用户名.workers.dev
3)复制 https://raw.githubusercontent.com/EtherDream/jsproxy/master/cf-worker/index.js 的内容到左侧代码(Script)区域
文章最下方有代码备份!!
4)先点击【Run】右侧看执行效果,再点击 【Save and deploy】 部署代码
5)届时你可以访问你的站点https://xxx.子域名.workers.dev查看效果
进入站点后将线路选择切换为当前站点即可使用
特别提示:浏览网站的时候,有时候会提示加载不安全脚本,点击允许即可!
代码备份
'use strict'/** * static files (404.html, sw.js, conf.js) */const ASSET_URL = 'https://zjcqoo.github.io'const JS_VER = 8const MAX_RETRY = 1const 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-allow-headers': '--raw-info,--level,--url,--referer,--cookie,--origin,--ext,--aceh,--ver,--type,--mode,accept,accept-charset,accept-encoding,accept-language,accept-datetime,authorization,cache-control,content-length,content-type,date,if-match,if-modified-since,if-none-match,if-range,if-unmodified-since,max-forwards,pragma,range,te,upgrade,upgrade-insecure-requests,x-requested-with,chrome-proxy,purpose','access-control-max-age': '1728000',}),}/** * @param {string} message * @param {number} status * @param {any} headers */function makeRes(message, status = 200, headers = {}) {headers['cache-control'] = 'no-cache'headers['vary'] = '--url'headers['access-control-allow-origin'] = '*'return new Response(message, {status, headers})}addEventListener('fetch', e => {const ret = fetchHandler(e).catch(err => makeRes('cfworker error:' + err, 502))e.respondWith(ret)})function fetchHandler(e) {const req = e.requestconst urlStr = req.urlconst urlObj = new URL(urlStr)if (urlObj.protocol === 'http:') {urlObj.protocol = 'https:'return makeRes('', 301, {'strict-transport-security': 'max-age=99999999; includeSubDomains; preload','location': urlObj.href,})}switch (urlObj.pathname) {case '/http':return httpHandler(req)case '/ws':return makeRes('not support', 400)case '/works':return makeRes('it works')default:// static filesreturn fetch(ASSET_URL + urlObj.pathname)}}/** * @param {Request} req */async function httpHandler(req) {const reqHdrRaw = req.headersif (reqHdrRaw.has('x-jsproxy')) {return Response.error()}// preflightif (req.method === 'OPTIONS' &&reqHdrRaw.has('access-control-request-headers')) {return new Response(null, PREFLIGHT_INIT)}let urlObj = nulllet extHdrs = nulllet acehOld = falselet rawSvr = ''let rawLen = ''let rawEtag = ''const reqHdrNew = new Headers(reqHdrRaw)reqHdrNew.set('x-jsproxy', '1')for (const [k, v] of reqHdrRaw.entries()) {if (!k.startsWith('--')) {continue}reqHdrNew.delete(k)const k2 = k.substr(2)switch (k2) {case 'url':urlObj = new URL(v)breakcase 'aceh':acehOld = truebreakcase 'raw-info':[rawSvr, rawLen, rawEtag] = v.split('|')breakcase 'level':case 'mode':case 'type':breakcase 'ext':extHdrs = JSON.parse(v)breakdefault:if (v) {reqHdrNew.set(k2, v)} else {reqHdrNew.delete(k2)}break}}if (extHdrs) {for (const [k, v] of Object.entries(extHdrs)) {reqHdrNew.set(k, v)}}if (!urlObj) {return makeRes('missing url param', 403)}/** @type {RequestInit} */const reqInit = {method: req.method,headers: reqHdrNew,}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.headersconst resHdrNew = new Headers(resHdrOld)let expose = '*'let vary = '--url'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 = '--' + kresHdrNew.set(x, v)if (acehOld) {expose = expose + ',' + x}resHdrNew.delete(k)}else if (k === 'vary') {vary = vary + ',' + v}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')}// verifyif (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('error', 400, {'--error': 'bad len:' + newLen})}if (retryTimes > 1) {resHdrNew.set('--retry', retryTimes)}}let status = res.statusresHdrNew.set('access-control-expose-headers', expose)resHdrNew.set('access-control-allow-origin', '*')resHdrNew.set('vary', vary)resHdrNew.set('--s', status)resHdrNew.set('--ver', JS_VER)resHdrNew.delete('content-security-policy')resHdrNew.delete('content-security-policy-report-only')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} |
猜你还喜欢
- 03-29 [web] 免费公共DNS大全(IPv6+IPv4)
- 03-29 [玩技术] CTFHUB刷题笔记
- 03-22 [AI配音] 有哪些好用的AI智能配音工具值得推荐?
- 03-15 [web] 轻松申请免费域名并绑定到个人网站 | link顶级域名
- 03-15 [运营] 亚马逊如何选品?产品市场分析怎么做?包括哪些方面?
- 03-15 [web] 3分钟,免费拥有你的专属域名——免费一级域名注册申请及域名解析教程
- 03-14 [学习] 必看!手把手教你自动续期微软E5账号,长期畅享5T OneDrive云盘!
- 03-14 [学习] 白嫖5T微软的OneDrive云盘,微软E5申请,真正的免费不限速!
- 03-14 [学习] 微软onedrive E5创建子账号,实现125T云盘空间25账号,附带Office365激活
- 03-05 [web] PT站是什么?开放注册的国外国内PT站推荐汇总
- 03-02 [web] 注册海外Visa万事达美国虚拟信用卡,轻松搞定ChatGPT4 Plus会员订阅
- 01-14 [web] 谷歌ai:“我是百度文心大模型”
取消回复欢迎 你 发表评论:
- 精品推荐!
-
- 最新文章
- 热门文章
- 热评文章
[编程相关] 熊猫脚本助手_吾爱专版 V1.9
[办公辅助] Office AI 助手免费版 v0.2.01
[配音工具] 一点红语音合成2.0版本 -吾爱专版
[电影] 2024年国产动作片《天坑鹰猎 电影版》HD国语中字
[电影] 2010年国产经典武侠片《镖行天下前传之燃眉危机》HD国语中字
[电影] 2021年国产动作片《妙手神探之鬼门十三针》HD国语中字
[课程] Procreate元计划板绘入门系统课程
[课程] DK图解数学动画课程
[有声读物] 儿童汉语分级读物《小羊上山》第1-4季PDF电子版+精读视频+MP3音频
[电影] 2023年国产爱情片《不要走散好不好》HD国语中字
[资料] [大学期末救急课] 猴博士+高斯课堂+斐多课堂,全集视频合集
[云资源] 价值2万元的老男孩Python教程
[书库] 史上最全摄影书推荐(附700本PDF版打包下载)
[云资源] 花了一千多元买的私人健身教程
[下载工具] Internet Download Manager 6.42.7 (IDM)
[影视] 灌篮高手 WEB-DL版下载/Slam Dunk/スラムダンク/灌篮高手:THE FIRST/灌篮高手电影版 2022 The First Slam Dunk 61.35G
[即时通讯] 腾讯QQ PC版9.7.22.29315去广告绿色纯净版
[开发环境] PhpStorm2023中文激活版v2023.3.3 正式版
[图像制作] Adobe Illustrator 2024 v28.1.0.141 破解版
[资料] 3000 套电影电视剧 LOGO 宣传片常用音效合集包
[云资源] 价值2万元的老男孩Python教程
[影视] 灌篮高手 WEB-DL版下载/Slam Dunk/スラムダンク/灌篮高手:THE FIRST/灌篮高手电影版 2022 The First Slam Dunk 61.35G
[云资源] 花了一千多元买的私人健身教程
[书库] 史上最全摄影书推荐(附700本PDF版打包下载)
[安卓软件] Android GIF助手 v3.9.7 GIF图片编辑器破解版
[电视剧] 三体 (2024) 全8集 网飞版本 中文字幕 合集
[剧集] 繁花 (2023)[全30集][打包]
[影视] 三大队 WEB-DL版下载/Endless Journey/请转告局长,三大队任务完成了 2023 三大队 6.7G
[纪录片] 河西走廊【10集 国语 中文字幕 1080P 10.8G MP4】
[安卓软件] OfficeSuite中文版APP v14.2.50872.0破解版
- 最新评论
-
好yinhq693 评论于:04-02 谢谢支持!!CC下载站 评论于:03-26 很棒的资源,感谢分享云体风身 评论于:03-26 感谢分享,好东西云体风身 评论于:03-26 谢谢支持!CC下载站 评论于:03-14 央视精品,感谢付出提供。qwer9009 评论于:03-14 谢谢支持!!!CC下载站 评论于:03-13 谢谢分享!Ypc9182 评论于:03-12 谢谢支持!!CC下载站 评论于:03-11 感谢本网站收集和提供这么多的资料,谢谢!Ypc9182 评论于:03-10
- 热门tag