URL Parsing

URL Parsing #

// URLs possibilitam [uma forma uniforme de encontar recursos](https://adam.herokuapp.com/past/2010/3/30/urls_are_the_uniform_way_to_locate_resources/).
// 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