Golang 的Gin框架入門教學

學習Golang差很少有一個星期時間,開始本身作點小功能,練練手。

Gin 介紹

Gin 是一個 Golang 寫的 web 框架,具備高性能的優勢,,基於 httprouter,
它提供了相似martini但更好性能(路由性能約快40倍)的API服務。
官方地址:https://github.com/gin-gonic/gin

安裝框架

配置好GOPATH,建議本身在GOPATH建個項目,這裏我以aze.org做爲項目目錄。mysql

$ go get github.com/gin-gonic/gingit

安裝mysql驅動

$ go get github.com/go-sql-driver/mysqlgithub

組織項目

通過上面的model和handler的分離,代碼結構變得更加清晰,但是咱們仍是單文件。下一步將進行封裝不一樣的包。golang

數據庫處理

在項目根目錄建立下面三個文件夾,apis,databases和models,並在文件夾內建立文件。此時咱們的目錄結果以下web

Golang 的Gin框架入門教學

apis文件夾存放咱們的handler函數,models文件夾用來存放咱們的數據模型。

mysql.go

package database

import (
 "database/sql"
 _ "github.com/go-sql-driver/mysql"
 "log"
)

var SqlDB *sql.DB

func init() {
 var err error
 SqlDB, err = sql.Open("mysql", "root:@tcp(127.0.0.1:3306)/test?parseTime=true")
 if err != nil {
  log.Fatal(err.Error())
 }
 err = SqlDB.Ping()
 if err != nil {
  log.Fatal(err.Error())
 }
}

由於咱們須要在別的地方使用SqlDB這個變量,所以依照golang的習慣,變量名必須大寫開頭。sql

數據model封裝

修改models文件夾下的person.go,把對應的Person結構及其方法移到這裏:數據庫

package models

import (
 "log"
 db "newland/database"
)

type Person struct {
 Id        int    `json:"id" form:"id"`
 FirstName string `json:"first_name" form:"first_name"`
 LastName  string `json:"last_name" form:"last_name"`
}

func (p *Person) AddPerson() (id int64, err error) {
 rs, err := db.SqlDB.Exec("INSERT INTO person(first_name, last_name) VALUES (?, ?)", p.FirstName, p.LastName)
 if err != nil {
  return
 }
 id, err = rs.LastInsertId()
 return
}

func (p *Person) GetPersons() (persons []Person, err error) {
 persons = make([]Person, 0)
 rows, err := db.SqlDB.Query("SELECT id, first_name, last_name FROM person")
 defer rows.Close()

 if err != nil {
  return
 }

 for rows.Next() {
  var person Person
  rows.Scan(&person.Id, &person.FirstName, &person.LastName)
  persons = append(persons, person)
 }
 if err = rows.Err(); err != nil {
  return
 }
 return
}
..............

handler

而後把具體的handler函數封裝到api包中,由於handler函數要操做數據庫,因此會引用model包json

package apis

import (
 "net/http"
 "log"
 "fmt"
 "github.com/gin-gonic/gin"
 . "aze.org/models"
)

func IndexApi(c *gin.Context) {
 c.String(http.StatusOK, "It works")
}

func AddPersonApi(c *gin.Context) {
 firstName := c.Request.FormValue("first_name")
 lastName := c.Request.FormValue("last_name")

 p := Person{FirstName: firstName, LastName: lastName}

 ra, err := p.AddPerson()
 if err != nil {
  log.Fatalln(err)
 }
 msg := fmt.Sprintf("insert successful %d", ra)
 c.JSON(http.StatusOK, gin.H{
  "msg": msg,
 })
}

......

路由

最後就是把路由抽離出來,修改router.go,咱們在路由文件中封裝路由函數api

package main

import (
 "github.com/gin-gonic/gin"
 . "aze.orgd/apis"
)

func initRouter() *gin.Engine {
 router := gin.Default()

 router.GET("/", IndexApi)

 router.POST("/person", AddPersonApi)

 router.GET("/persons", GetPersonsApi)

 router.GET("/person/:id", GetPersonApi)

 router.PUT("/person/:id", ModPersonApi)

 router.DELETE("/person/:id", DelPersonApi)

 return router
}

app入口

最後就是main函數的app入口,將路由導入,同時咱們要在main函數結束的時候,關閉全局的數據庫鏈接池:restful

main.go

package main

import (
 db "aze.org/database"
)

func main() {
 defer db.SqlDB.Close()
 router := initRouter()
 router.Run(":8000")
}

此時運行項目,不能像以前簡單的使用go run main.go,由於包main包含main.go和router.go的文件,所以須要運行go run *.go命令編譯運行。若是是最終編譯二進制項目,則運行go build -o app,生成app文件直接./app就能夠運行項目了。

總結

1.經過上述的實踐,咱們瞭解了Gin框架建立基本的的restful服務。
2.golang 關鍵字很少,可是語法仍是挺多的,須要認真學習,打好基礎。
3.多看優秀的框架,再進行思考有沒有更好的寫法。

參考教程:

Gin框架 詳細文檔地址:https://godoc.org/github.com/gin-gonic/gin

項目地址:

https://github.com/onebig32/gin-learn.git

相關文章
相關標籤/搜索