Fix gRPC service name escape

This commit is contained in:
H1JK 2023-04-08 17:44:11 +08:00 committed by 世界
parent ec2d0b6b3c
commit d5f94b65b7
No known key found for this signature in database
GPG key ID: CD109927C34A63C4
2 changed files with 5 additions and 7 deletions

View file

@ -12,7 +12,6 @@ import (
"github.com/sagernet/sing-box/common/tls" "github.com/sagernet/sing-box/common/tls"
"github.com/sagernet/sing-box/option" "github.com/sagernet/sing-box/option"
"github.com/sagernet/sing-box/transport/v2rayhttp" "github.com/sagernet/sing-box/transport/v2rayhttp"
F "github.com/sagernet/sing/common/format"
M "github.com/sagernet/sing/common/metadata" M "github.com/sagernet/sing/common/metadata"
N "github.com/sagernet/sing/common/network" N "github.com/sagernet/sing/common/network"
@ -50,7 +49,8 @@ func NewClient(ctx context.Context, dialer N.Dialer, serverAddr M.Socksaddr, opt
url: &url.URL{ url: &url.URL{
Scheme: "https", Scheme: "https",
Host: serverAddr.String(), Host: serverAddr.String(),
Path: F.ToString("/", url.QueryEscape(options.ServiceName), "/Tun"), Path: "/" + options.ServiceName + "/Tun",
RawPath: "/" + url.PathEscape(options.ServiceName) + "/Tun",
}, },
} }

View file

@ -2,10 +2,8 @@ package v2raygrpclite
import ( import (
"context" "context"
"fmt"
"net" "net"
"net/http" "net/http"
"net/url"
"os" "os"
"strings" "strings"
"time" "time"
@ -45,7 +43,7 @@ func NewServer(ctx context.Context, options option.V2RayGRPCOptions, tlsConfig t
server := &Server{ server := &Server{
tlsConfig: tlsConfig, tlsConfig: tlsConfig,
handler: handler, handler: handler,
path: fmt.Sprintf("/%s/Tun", url.QueryEscape(options.ServiceName)), path: "/" + options.ServiceName + "/Tun",
h2Server: &http2.Server{ h2Server: &http2.Server{
IdleTimeout: time.Duration(options.IdleTimeout), IdleTimeout: time.Duration(options.IdleTimeout),
}, },