From c5a417da8f041896aa4eb304c89879c997d00d2f Mon Sep 17 00:00:00 2001 From: xream Date: Mon, 3 Jun 2024 21:14:07 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20VMess=20URI=20=E6=94=AF=E6=8C=81=20TCP/?= =?UTF-8?q?H2=20=E4=BC=A0=E8=BE=93=E5=B1=82?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- backend/package.json | 2 +- backend/src/core/proxy-utils/parsers/index.js | 11 +++++++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/backend/package.json b/backend/package.json index 2b6851fbd..a903b2d05 100644 --- a/backend/package.json +++ b/backend/package.json @@ -1,6 +1,6 @@ { "name": "sub-store", - "version": "2.14.332", + "version": "2.14.333", "description": "Advanced Subscription Manager for QX, Loon, Surge, Stash and ShadowRocket.", "main": "src/main.js", "scripts": { diff --git a/backend/src/core/proxy-utils/parsers/index.js b/backend/src/core/proxy-utils/parsers/index.js index a3d71d2ed..2f96479ec 100644 --- a/backend/src/core/proxy-utils/parsers/index.js +++ b/backend/src/core/proxy-utils/parsers/index.js @@ -305,8 +305,9 @@ function URI_VMess() { if (params.net === 'ws' || params.obfs === 'websocket') { proxy.network = 'ws'; } else if ( - ['tcp', 'http'].includes(params.net) || - params.obfs === 'http' + ['http'].includes(params.net) || + ['http'].includes(params.obfs) || + ['http'].includes(params.type) ) { proxy.network = 'http'; } else if (['grpc'].includes(params.net)) { @@ -317,6 +318,8 @@ function URI_VMess() { ) { proxy.network = 'ws'; httpupgrade = true; + } else if (params.net === 'h2' || proxy.network === 'h2') { + proxy.network = 'h2'; } if (proxy.network) { let transportHost = params.host ?? params.obfsParam; @@ -332,6 +335,10 @@ function URI_VMess() { if (proxy.network === 'http') { if (transportHost) { + // 1)http(tcp)->host中间逗号(,)隔开 + transportHost = transportHost + .split(',') + .map((i) => i.trim()); transportHost = Array.isArray(transportHost) ? transportHost[0] : transportHost;