gorose orm+dotweb框架快速構建go web網站實戰(四)

路由規劃

路由是全部請求的入口, 在這裏, 咱們配置全部的請求, 爲每個請求去上對應的名字, 並根據名字去請求不一樣的控制器, 從而獲取最終的數據
在這裏, 咱們作出了簡單的代碼示例以下:git

package router

import (
    // 引入控制器
    "github.com/gohouse/kuaixinwen/controller"
    // 引入dotweb
    "github.com/devfeel/dotweb"
    // 引入dotweb中間件
    "github.com/devfeel/middleware/cors"
)

func Run(Route *dotweb.HttpServer) {
    // 設置cors選項中間件, 並使用默認的跨域配置
    option := cors.NewConfig().UseDefault()

    // 首頁測試 /
    Route.GET("/", func(ctx dotweb.Context) error {
        return ctx.WriteString("快新聞首頁!")
    })
    // json返回測試 /json
    Route.GET("/json", func(ctx dotweb.Context) error {
        return ctx.WriteJson("浪裏個浪...")
    }).Use(cors.Middleware(option))

    // 前臺展現列表 /getnewslist
    Route.GET("/getnewslist", controller.GetNewsList).Use(cors.Middleware(option))

    // 後臺管理
    admin := Route.Group("/admin").Use(cors.Middleware(option))
    // 新聞列表 /admin/newsdel
    admin.GET("/getnewslist", controller.GetNewsList)
    // 獲取單條新聞信息 /admin/getnewsbyid
    admin.GET("/getnewsbyid", controller.GetNewsById)
    // 新聞增長或修改, 根據是否傳了id來斷定, 傳了id就修改, 不然增長 /admin/newsaddoredit
    admin.POST("/newsaddoredit", controller.NewsAddOrEdit)
    // 新聞刪除 /admin/newsdel
    admin.POST("/newsdel", controller.NewsDel)
}

說明

這裏用到了 dotweb 的相關組件, 有 HttpServer , Contextcors 中間件
他們分別做用於 路由, 請求參數等相關和中間件(好比跨域) 等github

  • Route.GET 表明該請求位 get 請求
  • Route.POST 表明該請求位 post 請求
  • Route.Group 將請求歸類, 示例中是將後臺管理的請求所有歸類到 admin 下邊
  • Route.Group.Use 使用中間件
  • option 中間件初始化
  • cors.Middleware(option) 加載中間件option
  • controller.xxxxx 加載控制器的對應方法

這裏路由部分就完成了, 止於加載的控制器 controller 部分, 見下一節web


本項目源碼: https://github.com/gohouse/kuaixinwenjson

相關文章
相關標籤/搜索