mirror of
https://github.com/xvzc/SpoofDPI.git
synced 2024-12-31 07:04:39 +00:00
update packet parsing
This commit is contained in:
parent
9f742582c5
commit
729008083e
@ -108,7 +108,7 @@ func (lConn *Conn) HandleHttp(p *packet.HttpPacket) {
|
|||||||
// Create connection to server
|
// Create connection to server
|
||||||
var port = ":80"
|
var port = ":80"
|
||||||
if p.Port() != "" {
|
if p.Port() != "" {
|
||||||
port = p.Port()
|
port = ":" + p.Port()
|
||||||
}
|
}
|
||||||
|
|
||||||
rConn, err := Dial("tcp", ip + port)
|
rConn, err := Dial("tcp", ip + port)
|
||||||
@ -154,7 +154,7 @@ func (lConn *Conn) HandleHttps(p *packet.HttpPacket) {
|
|||||||
// Create a connection to the requested server
|
// Create a connection to the requested server
|
||||||
var port = ":443"
|
var port = ":443"
|
||||||
if p.Port() != "" {
|
if p.Port() != "" {
|
||||||
port = p.Port()
|
port = ":" + p.Port()
|
||||||
}
|
}
|
||||||
|
|
||||||
rConn, err := Dial("tcp", ip + port)
|
rConn, err := Dial("tcp", ip + port)
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
package packet
|
package packet
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"bufio"
|
||||||
|
"net"
|
||||||
|
"net/http"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -122,58 +124,34 @@ func (p *HttpPacket) Tidy() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p *HttpPacket )parse() error {
|
func (p *HttpPacket )parse() error {
|
||||||
var firstLine string
|
reader := bufio.NewReader(strings.NewReader(string(p.raw)))
|
||||||
for i := 0; i < len(p.raw); i++ {
|
request, err := http.ReadRequest(reader)
|
||||||
if (p.raw)[i] == '\r' {
|
if err != nil {
|
||||||
firstLine = string(p.raw[:i])
|
return err
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tokens := strings.Split(firstLine, " ")
|
|
||||||
|
|
||||||
if (len(tokens) < 3) {
|
|
||||||
return errors.New("Error parsing http request")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
p.method = tokens[0]
|
p.domain, p.port, err = net.SplitHostPort(request.Host)
|
||||||
url := tokens[1]
|
if err != nil {
|
||||||
p.version = tokens[2]
|
p.domain = request.Host
|
||||||
|
p.port = ""
|
||||||
if strings.HasPrefix(url, "http://") {
|
|
||||||
url = strings.Replace(url, "http://", "", 1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if strings.HasPrefix(url, "https://") {
|
p.method = request.Method
|
||||||
url = strings.Replace(url, "https://", "", 1)
|
p.version = request.Proto
|
||||||
|
p.path = request.URL.Path
|
||||||
|
|
||||||
|
if request.URL.RawQuery != "" {
|
||||||
|
p.path += "?" + request.URL.RawQuery
|
||||||
}
|
}
|
||||||
|
|
||||||
domain := ""
|
if request.URL.RawFragment != "" {
|
||||||
port := ""
|
p.path += "#" + request.URL.RawFragment
|
||||||
for i := 0; i < len(url); i++ {
|
}
|
||||||
if url[i] == ':' {
|
if p.path == "" {
|
||||||
domain = url[:i]
|
p.path = "/"
|
||||||
port = url[i:]
|
}
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
if url[i] == '/' {
|
request.Body.Close()
|
||||||
domain = url[:i]
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
p.domain = domain
|
|
||||||
p.port = port
|
|
||||||
|
|
||||||
path := "/"
|
|
||||||
for i := 0; i < len(url); i++ {
|
|
||||||
if url[i] == '/' {
|
|
||||||
path = url[i:]
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
p.path = path
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user