路由是全部请求的入口, 在这里, 咱们配置全部的请求, 为每个请求去上对应的名字, 并根据名字去请求不一样的控制器, 从而获取最终的数据
在这里, 咱们作出了简单的代码示例以下: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
, Context
和 cors
中间件
他们分别做用于 路由, 请求参数等相关和中间件(好比跨域) 等github
Route.GET
表明该请求位 get 请求Route.POST
表明该请求位 post 请求Route.Group
将请求归类, 示例中是将后台管理的请求所有归类到 admin
下边Route.Group.Use
使用中间件option
中间件初始化cors.Middleware(option)
加载中间件optioncontroller.xxxxx
加载控制器的对应方法这里路由部分就完成了, 止于加载的控制器 controller
部分, 见下一节web