|  | 6 years ago | |
|---|---|---|
| .. | ||
| .travis.yml | 6 years ago | |
| LICENSE | 8 years ago | |
| README.md | 6 years ago | |
| cache.go | 6 years ago | |
| converter.go | 6 years ago | |
| decoder.go | 6 years ago | |
| doc.go | 6 years ago | |
Package gorilla/schema fills a struct with form values.
Here's a quick example: we parse POST form values and then decode them into a struct:
// Set a Decoder instance as a package global, because it caches 
// meta-data about structs, and an instance can be shared safely.
var decoder = schema.NewDecoder()
type Person struct {
    Name  string
    Phone string
}
func MyHandler(w http.ResponseWriter, r *http.Request) {
    err := r.ParseForm()
    if err != nil {
        // Handle error
    }
    var person Person
    
    // r.PostForm is a map of our POST form values
    err := decoder.Decode(&person, r.PostForm)
    if err != nil {
        // Handle error
    }
    // Do something with person.Name or person.Phone
}
To define custom names for fields, use a struct tag "schema". To not populate certain fields, use a dash for the name and it will be ignored:
type Person struct {
    Name  string `schema:"name"`  // custom name
    Phone string `schema:"phone"` // custom name
    Admin bool   `schema:"-"`     // this field is never set
}
The supported field types in the destination struct are:
Unsupported types are simply ignored, however custom types can be registered to be converted.
More examples are available on the Gorilla website: http://www.gorillatoolkit.org/pkg/schema
BSD licensed. See the LICENSE file for details.