2017-08-18 16:09:18 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/kataras/iris"
|
|
|
|
|
|
|
|
"github.com/kataras/iris/middleware/logger"
|
|
|
|
"github.com/kataras/iris/middleware/recover"
|
|
|
|
)
|
|
|
|
|
|
|
|
// This example is equivalent to the
|
|
|
|
// https://github.com/kataras/iris/blob/master/_examples/hello-world/main.go
|
|
|
|
//
|
|
|
|
// It seems that additional code you
|
|
|
|
// have to write doesn't worth it
|
|
|
|
// but remember that, this example
|
|
|
|
// does not make use of iris mvc features like
|
|
|
|
// the Model, Persistence or the View engine neither the Session,
|
|
|
|
// it's very simple for learning purposes,
|
|
|
|
// probably you'll never use such
|
|
|
|
// as simple controller anywhere in your app.
|
|
|
|
//
|
|
|
|
// The cost we have on this example for using MVC
|
|
|
|
// on the "/hello" path which serves JSON
|
|
|
|
// is ~2MB per 20MB throughput on my personal laptop,
|
|
|
|
// it's tolerated for the majority of the applications
|
|
|
|
// but you can choose
|
|
|
|
// what suits you best with Iris, low-level handlers: performance
|
|
|
|
// or high-level controllers: easier to maintain and smaller codebase on large applications.
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
app := iris.New()
|
|
|
|
// Optionally, add two built'n handlers
|
|
|
|
// that can recover from any http-relative panics
|
|
|
|
// and log the requests to the terminal.
|
|
|
|
app.Use(recover.New())
|
|
|
|
app.Use(logger.New())
|
|
|
|
|
2017-09-02 13:32:14 +02:00
|
|
|
app.Controller("/", new(ExampleController))
|
2017-08-18 16:09:18 +02:00
|
|
|
|
|
|
|
// http://localhost:8080
|
|
|
|
// http://localhost:8080/ping
|
|
|
|
// http://localhost:8080/hello
|
|
|
|
app.Run(iris.Addr(":8080"))
|
|
|
|
}
|
|
|
|
|
2017-09-02 13:32:14 +02:00
|
|
|
// ExampleController serves the "/", "/ping" and "/hello".
|
|
|
|
type ExampleController struct {
|
2017-08-28 10:40:25 +02:00
|
|
|
// if you build with go1.8 you have to use the mvc package, `mvc.Controller` instead.
|
|
|
|
iris.Controller
|
2017-08-18 16:09:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get serves
|
|
|
|
// Method: GET
|
2017-09-02 13:32:14 +02:00
|
|
|
// Resource: http://localhost:8080
|
|
|
|
func (c *ExampleController) Get() {
|
|
|
|
c.ContentType = "text/html"
|
|
|
|
c.Text = "<h1>Welcome!</h1>"
|
2017-08-18 16:09:18 +02:00
|
|
|
}
|
|
|
|
|
2017-09-02 13:32:14 +02:00
|
|
|
// GetPing serves
|
2017-08-18 16:09:18 +02:00
|
|
|
// Method: GET
|
2017-08-24 14:51:43 +02:00
|
|
|
// Resource: http://localhost:8080/ping
|
2017-09-02 13:32:14 +02:00
|
|
|
func (c *ExampleController) GetPing() {
|
|
|
|
c.Text = "pong"
|
2017-08-18 16:09:18 +02:00
|
|
|
}
|
|
|
|
|
2017-09-02 13:32:14 +02:00
|
|
|
// GetHello serves
|
2017-08-18 16:09:18 +02:00
|
|
|
// Method: GET
|
|
|
|
// Resource: http://localhost:8080/hello
|
2017-09-02 13:32:14 +02:00
|
|
|
func (c *ExampleController) GetHello() {
|
|
|
|
c.Ctx.JSON(iris.Map{"message": "Hello Iris!"})
|
2017-08-18 16:09:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Can use more than one, the factory will make sure
|
|
|
|
that the correct http methods are being registered for each route
|
|
|
|
for this controller, uncomment these if you want:
|
|
|
|
|
2017-09-02 13:32:14 +02:00
|
|
|
func (c *ExampleController) Post() {}
|
|
|
|
func (c *ExampleController) Put() {}
|
|
|
|
func (c *ExampleController) Delete() {}
|
|
|
|
func (c *ExampleController) Connect() {}
|
|
|
|
func (c *ExampleController) Head() {}
|
|
|
|
func (c *ExampleController) Patch() {}
|
|
|
|
func (c *ExampleController) Options() {}
|
|
|
|
func (c *ExampleController) Trace() {}
|
2017-08-18 16:09:18 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-09-02 13:32:14 +02:00
|
|
|
func (c *ExampleController) All() {}
|
2017-08-18 16:09:18 +02:00
|
|
|
// OR
|
2017-09-02 13:32:14 +02:00
|
|
|
func (c *ExampleController) Any() {}
|
2017-08-18 16:09:18 +02:00
|
|
|
*/
|