Socks4a server: Check if the client sends an IP address as domain (#3628)

Fixes https://github.com/XTLS/Xray-core/issues/3622
pull/3634/head
风扇滑翔翼 2024-08-03 10:08:23 +08:00 committed by GitHub
parent 7e24239c9a
commit 644901d1a5
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 6 additions and 1 deletions

View File

@ -121,6 +121,11 @@ func IPAddress(ip []byte) Address {
} }
// DomainAddress creates an Address with given domain. // DomainAddress creates an Address with given domain.
// This is an internal function that forcibly converts a string to domain.
// It's mainly used in test files and mux.
// Unless you have a specific reason, use net.ParseAddress instead,
// as this function does not check whether the input is an IP address.
// Otherwise, you will get strange results like domain: 1.1.1.1
func DomainAddress(domain string) Address { func DomainAddress(domain string) Address {
return domainAddress(domain) return domainAddress(domain)
} }

View File

@ -74,7 +74,7 @@ func (s *ServerSession) handshake4(cmd byte, reader io.Reader, writer io.Writer)
if err != nil { if err != nil {
return nil, errors.New("failed to read domain for socks 4a").Base(err) return nil, errors.New("failed to read domain for socks 4a").Base(err)
} }
address = net.DomainAddress(domain) address = net.ParseAddress(domain)
} }
switch cmd { switch cmd {