Go 언어의 웹 프레임워크 "Echo"①(Hello World의)

10644 단어 Goecho
모든 문장의 일람표는 여기에 있다.
Go 언어로 웹 사이트 만들기: 목록
http://qiita.com/y_ussie/items/8fcc3077274449478bc9
Qiita 기고는 이번이 처음입니다.
Go의 웹 프레임워크를 사용해 Martini와 Gin을 조사해 보고 싶었지만, 에코는 새로운 프레임워크 개발도 활발한 것 같아 기본적인 사용법을 시도해 보기로 했다.

하고 싶은 일


다음 요청을 처리합니다.

GET /


다음 템플릿으로 생성된 HTML을 반환합니다.
모든 페이지에 공통으로 적용되는 레이아웃 템플릿
templates/layout.html
<html>
  <head>
    <title>Echo HTML Server Sample</title>
  </head>
  <body>
    <!-- Render the current template here -->
    {{template "content" .}}
  </body>
</html>
각 컨텐츠의 템플릿
templates/hello.html
{{define "content"}}
<h2>Hello {{.}}!</h2>
{{end}}

GET /api/hello


다음 JSON으로 돌아갑니다.
{"hello": "world"}

GET /public/css | js | img


정적 파일을 반환합니다.

그래서 나는 각양각색의 자료를 찾아보면서 썼다


main.go
package main

import (
    "html/template"
    "io"
    "net/http"

    "github.com/labstack/echo"
    "github.com/labstack/echo/middleware"
)

// レイアウト適用済のテンプレートを保存するmap
var templates map[string]*template.Template

// Template はHTMLテンプレートを利用するためのRenderer Interfaceです。
type Template struct {
}

// Render はHTMLテンプレートにデータを埋め込んだ結果をWriterに書き込みます。
func (t *Template) Render(w io.Writer, name string, data interface{}, c echo.Context) error {
    return templates[name].ExecuteTemplate(w, "layout.html", data)
}

func main() {
    // Echoのインスタンスを生成
    e := echo.New()

    // テンプレートを利用するためのRendererの設定
    t := &Template{}
    e.Renderer = t

    // ミドルウェアを設定
    e.Use(middleware.Logger())
    e.Use(middleware.Recover())

    // 静的ファイルのパスを設定
    e.Static("/public/css/", "./public/css")
    e.Static("/public/js/", "./public/js/")
    e.Static("/public/img/", "./public/img/")

    // 各ルーティングに対するハンドラを設定
    e.GET("/", HandleIndexGet)
    e.GET("/api/hello", HandleAPIHelloGet)

    // サーバーを開始
    e.Logger.Fatal(e.Start(":3000"))
}

// 初期化を行います。
func init() {
    loadTemplates()
}

// 各HTMLテンプレートに共通レイアウトを適用した結果を保存します(初期化時に実行)。
func loadTemplates() {
    var baseTemplate = "templates/layout.html"
    templates = make(map[string]*template.Template)
    templates["index"] = template.Must(
        template.ParseFiles(baseTemplate, "templates/hello.html"))
}

// HandleIndexGet は Index のGet時のHTMLデータ生成処理を行います。
func HandleIndexGet(c echo.Context) error {
    return c.Render(http.StatusOK, "index", "World")
}

// HandleAPIHelloGet は /api/hello のGet時のJSONデータ生成処理を行います。
func HandleAPIHelloGet(c echo.Context) error {
    return c.JSON(http.StatusOK, map[string]interface{}{"hello": "world"})
}
처음에는 에코의 가이드https://echo.labstack.com/guide를 보면서 쓰기 시작했지만, 공동 레이아웃 템플릿의 적용부분 등은 이쪽https://github.com/vitorsvieira/go-gin-boilerplate의 진의 샘플에서 에코로 이식됐다.
기본적으로 리뷰를 보면 알 수 있는 코드로, 처음에는 로드 템플렉스(load Templates)로 사전에 레이아웃 디자인이 적용된 템플릿을 맵에 집어넣고, 템플렉스 #Render()로 맵에서 템플릿을 끌어내 처리한 곳에 초점을 맞췄다.
Go 자신이 최근에 공부하고 있어서 많은 착오가 있을 수 있다.

실행 결과


GET /



GET /api/hello



향후의 발전

  • 세션 관리
  • 처리 형식
  • 파일 업로드
  • 잠깐만요.

    좋은 웹페이지 즐겨찾기