1

路由规划

路由是所有请求的入口, 在这里, 我们配置所有的请求, 为每一个请求去上对应的名字, 并根据名字去请求不同的控制器, 从而获取最终的数据
在这里, 我们做出了简单的代码示例如下:

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 中间件
他们分别作用于 路由, 请求参数等相关和中间件(比如跨域) 等

  • Route.GET 代表该请求位 get 请求
  • Route.POST 代表该请求位 post 请求
  • Route.Group 将请求归类, 示例中是将后台管理的请求全部归类到 admin 下边
  • Route.Group.Use 使用中间件
  • option 中间件初始化
  • cors.Middleware(option) 加载中间件option
  • controller.xxxxx 加载控制器的对应方法

这里路由部分就完成了, 止于加载的控制器 controller 部分, 见下一节


本项目源码: https://github.com/gohouse/kuaixinwen


fizz
190 声望25 粉丝

gopher, phper