Go Em Exemplos: URL Parsing

URLs possibilitam uma forma uniforme de encontar recursos. Aqui está como parsear URLs em Go.

package main
import (
    "fmt"
    "net"
    "net/url"
)
func main() {

Aqui será parseado esta URL de exemplo, que inclui schema, informação de autênticação, host, porta, caminho (path), query params, e fragmentos de query.

    s := "postgres://user:pass@host.com:5432/path?k=v#f"

Aqui a URL é parseada e assegurada de que não ocorreram erros.

    u, err := url.Parse(s)
    if err != nil {
        panic(err)
    }

Para acessar o schema é bem direto.

    fmt.Println(u.Scheme)

User contem toda informação de autenticação; Username e Password exibem a respectiva valor.

    fmt.Println(u.User)
    fmt.Println(u.User.Username())
    p, _ := u.User.Password()
    fmt.Println(p)

O Host contem tanto hostname quanto a porta, se presente. A função SplitHostPort separa os dados.

    fmt.Println(u.Host)
    host, port, _ := net.SplitHostPort(u.Host)
    fmt.Println(host)
    fmt.Println(port)

Aqui são extraídos o path e o fragmento depois de #.

    fmt.Println(u.Path)
    fmt.Println(u.Fragment)

Para obter os query params em uma string de formato chave=valor, usa-se RawQuery. Também é possível parsear query params para um map. Os maps de query params parseados são formatados em map[string][]string então, para acessar o primeiro valor da primeira chave, é necessário utilizar [0].

    fmt.Println(u.RawQuery)
    m, _ := url.ParseQuery(u.RawQuery)
    fmt.Println(m)
    fmt.Println(m["k"])
    fmt.Println(m["k"][0])
}

Executando o código de parseamento de URLs, são exibidas todas as partes extraídas.

$ go run url-parsing.go 
postgres
user:pass
user
pass
host.com:5432
host.com
5432
/path
f
chave=valor&outrachave=outrovalor
map[chave:[valor] outrachave:[outrovalor]]
[valor]
valor

Próximo exemplo: SHA256 Hashes.