Response
Send String
Context#String(code int, s string)
can be used to send plain text response with status
code.
Example
func(c echo.Context) error {
return c.String(http.StatusOK, "Hello, World!")
}
Send HTML (Reference to templates)
Context#HTML(code int, html string)
can be used to send simple HTML response with
status code. If you are looking to send dynamically generate HTML see templates.
Example
func(c echo.Context) error {
return c.HTML(http.StatusOK, "<strong>Hello, World!</strong>")
}
Send HTML Blob
Context#HTMLBlob(code int, b []byte)
can be used to send HTML blob with status
code. You may find it handy using with a template engine which outputs []byte
.
Render Template
Send JSON
Context#JSON(code int, i interface{})
can be used to encode a provided Go type into
JSON and send it as response with status code.
Example
// User
type User struct {
Name string `json:"name" xml:"name"`
Email string `json:"email" xml:"email"`
}
// Handler
func(c echo.Context) error {
u := &User{
Name: "Jon",
Email: "[email protected]",
}
return c.JSON(http.StatusOK, u)
}
Stream JSON
Context#JSON()
internally uses json.Marshal
which may not be efficient to large JSON,
in that case you can directly stream JSON.
Example
func(c echo.Context) error {
u := &User{
Name: "Jon",
Email: "[email protected]",
}
c.Response().Header().Set(echo.HeaderContentType, echo.MIMEApplicationJSONCharsetUTF8)
c.Response().WriteHeader(http.StatusOK)
return json.NewEncoder(c.Response()).Encode(u)
}
JSON Pretty
Context#JSONPretty(code int, i interface{}, indent string)
can be used to a send
a JSON response which is pretty printed based on indent, which could be spaces or tabs.
Example below sends a pretty print JSON indented with spaces:
func(c echo.Context) error {
u := &User{
Name: "Jon",
Email: "[email protected]",
}
return c.JSONPretty(http.StatusOK, u, " ")
}
{
"email": "[email protected]",
"name": "Jon"
}
You can also use Context#JSON()
to output a pretty printed JSON (indented with spaces)
by appending pretty
in the request URL query string.
Example
curl http://localhost:1323/users/1?pretty
JSON Blob
Context#JSONBlob(code int, b []byte)
can be used to send pre-encoded JSON blob directly
from external source, for example, database.
Example
func(c echo.Context) error {
encodedJSON := []byte{} // Encoded JSON from external source
return c.JSONBlob(http.StatusOK, encodedJSON)
}
Send JSONP
Context#JSONP(code int, callback string, i interface{})
can be used to encode a provided
Go type into JSON and send it as JSONP payload constructed using a callback, with
status code.
Send XML
Context#XML(code int, i interface{})
can be used to encode a provided Go type into
XML and send it as response with status code.
Example
func(c echo.Context) error {
u := &User{
Name: "Jon",
Email: "[email protected]",
}
return c.XML(http.StatusOK, u)
}
Stream XML
Context#XML
internally uses xml.Marshal
which may not be efficient to large XML,
in that case you can directly stream XML.
Example
func(c echo.Context) error {
u := &User{
Name: "Jon",
Email: "[email protected]",
}
c.Response().Header().Set(echo.HeaderContentType, echo.MIMEApplicationXMLCharsetUTF8)
c.Response().WriteHeader(http.StatusOK)
return xml.NewEncoder(c.Response()).Encode(u)
}
XML Pretty
Context#XMLPretty(code int, i interface{}, indent string)
can be used to a send
an XML response which is pretty printed based on indent, which could be spaces or tabs.
Example below sends a pretty print XML indented with spaces:
func(c echo.Context) error {
u := &User{
Name: "Jon",
Email: "[email protected]",
}
return c.XMLPretty(http.StatusOK, u, " ")
}
<?xml version="1.0" encoding="UTF-8"?>
<User>
<Name>Jon</Name>
<Email>[email protected]</Email>
</User>
You can also use Context#XML()
to output a pretty printed XML (indented with spaces) by appending pretty
in the request URL query string.
Example
curl http://localhost:1323/users/1?pretty
XML Blob
Context#XMLBlob(code int, b []byte)
can be used to send pre-encoded XML blob directly
from external source, for example, database.
Example
func(c echo.Context) error {
encodedXML := []byte{} // Encoded XML from external source
return c.XMLBlob(http.StatusOK, encodedXML)
}