Request Parameters - Auto Bind
This document provides insights into aah’s Request Parameters auto parse and bind capabilities. So that you can take full advantage of them.
aah provides two ways to access your request parameters:
- Since v0.8 Auto Parse and Bind, this should be the preferred method.
- Use
ctx.Req.*
methods to get values.
Note: Auto Parse and Bind prevents the XSS attacks by sanitizing values. It is highly recommended to use.
Auto Parse and Bind
aah provides very flexible way to parse and bind request values into appropriate Go data types. It supports following:
- Bind any
Path
,Form
,Query
into controller action parameters, examples - Bind
JSON
orXML
request body intostruct
, examples - Bind any
Path
,Form
,Query
into controller actionstruct
fields, examples - Bind any
Path
,Form
,Query
into nestedstruct
following.
notation convention, examples - Bind supports bind of pointer and non-pointer, examples
- And you can also do combinations of above options
- You can added your own custom Value Parser by Type
Parse and Bind Priority
request.auto_bind.*
configuration is used for auto parse and bind. refer to config.
Supported Data Types
Binding of both pointer and non-pointer is supported.
- int, int8, int16, int32, int64
- uint, uint8, uint16, uint32, uint64
- float32, float64
- string
- bool - 1, t, T, true, TRUE, True, on, On will result as
true
- slice -
[]<type>
and[]*<type>
supported time.Time
- gets parsed based onformat.time = [...]
config from aah.confstruct
types- Type aliases of built-in types
- Custom types and aliases add your own value parser
Note:
- Any auto parse error will result into
400 Bad Request
, error details gets logged. - Multipart file binding is intentionally not supported by auto bind. It is mainly to use resources effectively. So aah provides dedicated methods
ctx.Req.SaveFile
,ctx.Req.SaveFiles
for your convenience to save uploaded multipart-form files into disk easily.
Auto Parse and Bind Example Snippets
Following examples provides an idea to get started quickly with auto parse and bind feature. Let’s start with simple one.
Go with your creativity and use case to exploit the auto parse and bind feature.
Getting Pagination Values
Getting Pagination Values into struct
Getting JSON Request Body into struct
Same principle is applicable for XML
content-type too.
Getting Values into struct
and nested struct
Here we’re gonna use the user profile fields. Focus on how form fields residence.*
and shipping.*
are mapped into struct fields with .
notation.
Adding Custom Value Parser by Type
Implement your value parser per interface valpar.Parser
.
Then add your parser into aah as follows: