mirror of
https://github.com/labstack/echo.git
synced 2025-01-10 00:28:23 +02:00
f4b0004d2b
Signed-off-by: Vishal Rana <vr@labstack.com>
99 lines
1.8 KiB
Markdown
99 lines
1.8 KiB
Markdown
+++
|
|
title = "HTTP Request"
|
|
description = "Handling HTTP request in Echo"
|
|
[menu.side]
|
|
name = "Request"
|
|
parent = "guide"
|
|
weight = 6
|
|
+++
|
|
|
|
## Request
|
|
|
|
### Bind Request Body
|
|
|
|
To bind request body into a provided Go type use `Context#Bind(interface{})`.
|
|
The default binder supports decoding application/json, application/xml and
|
|
application/x-www-form-urlencoded payload based on Context-Type header.
|
|
|
|
*Example*
|
|
|
|
TODO
|
|
|
|
> Custom binder can be registered via `Echo#SetBinder(Binder)`
|
|
|
|
### Query Parameter
|
|
|
|
Query parameter can be retrieved by name using `Context#QueryParam(name string)`.
|
|
|
|
*Example*
|
|
|
|
```go
|
|
e.GET("/users", func(c echo.Context) error {
|
|
name := c.QueryParam("name")
|
|
return c.String(http.StatusOK, name)
|
|
})
|
|
```
|
|
|
|
```sh
|
|
$ curl -G -d "name=joe" http://localhost:1323/users
|
|
```
|
|
|
|
### Form Parameter
|
|
|
|
Form parameter can be retrieved by name using `Context#FormValue(name string)`.
|
|
|
|
*Example*
|
|
|
|
```go
|
|
e.POST("/users", func(c echo.Context) error {
|
|
name := c.FormValue("name")
|
|
return c.String(http.StatusOK, name)
|
|
})
|
|
```
|
|
|
|
```sh
|
|
$ curl -d "name=joe" http://localhost:1323/users
|
|
```
|
|
|
|
### Path Parameter
|
|
|
|
Registered path parameter can be retrieved either by name `Context#Param(name string) string`
|
|
or by index `Context#P(i int) string`. Getting parameter by index gives a slightly
|
|
better performance.
|
|
|
|
*Example*
|
|
|
|
```go
|
|
e.GET("/users/:name", func(c echo.Context) error {
|
|
// By name
|
|
name := c.Param("name")
|
|
|
|
// By index
|
|
name := c.P(0)
|
|
|
|
return c.String(http.StatusOK, name)
|
|
})
|
|
```
|
|
|
|
```sh
|
|
$ curl http://localhost:1323/users/joe
|
|
```
|
|
|
|
|
|
### Handler Path
|
|
|
|
`Context#Path()` returns the registered path for the handler, it can be used in the
|
|
middleware for logging purpose.
|
|
|
|
*Example*
|
|
|
|
```go
|
|
e.Use(func(c echo.Context) error {
|
|
println(c.Path()) // Prints `/users/:name`
|
|
return nil
|
|
})
|
|
e.GET("/users/:name", func(c echo.Context) error) {
|
|
return c.String(http.StatusOK, name)
|
|
})
|
|
```
|