https://www.cnblogs.com/hezhixiong/p/4602671.html
近日在学习beego框架,今天把beego框架中的路由设置这一块进行了动手实践,感觉beego框架的路由功能还是蛮强大的。参考原文:http://beego.me/docs/mvc/controller/router.md#namespace
修改过程中主要是修改了routers/router.go文件,当然也有修改controllers/default.go,views/index.tpl和自己追加了一个login.html页面。这里主要是动手实践路由配置,所以仅仅保持路由的代码。
routers/router.go
package routers
import (
"beegorouter/controllers"
"github.com/astaxie/beego"
"github.com/astaxie/beego/context"
)
func init() {
// bee 工具自动生成的固定路由
beego.Router("/", &controllers.MainController{})
// beego路由实践,参考文档:http://beego.me/docs/mvc/controller/router.md
/**
* 基础路由实践
*/
/**
* 基本Get路由实践
* 注意事项:需要导入包:github.com/astaxie/beego/context
* 否则【context.Context】会编译出错
* 测试用例:浏览器里输入:http://localhost:8080/get
* 输出结果:在浏览器页面里显示:基本Get路由实践。
*/
beego.Get("/get", func(ctx *context.Context) {
ctx.Output.Body([]byte("基本Get路由实践。"))
})
/**
* 基本Post路由实践
* 注意事项:需要修改或是追加html页面,从页面提交一个post请求
* 测试用例:修改index.tpl模板,追加一按钮,指定method="post",点击该按钮
* 输出结果:基本Post路由实践。
*/
beego.Post("/post", func(ctx *context.Context) {
ctx.Output.Body([]byte("基本Post路由实践。"))
})
/**
* 正则路由实践
*/
/**
* 正则路由实践
* 注意事项:1. 第二个参数需要传递一个控制器:Controller
* 2. 【?:id】 中的id也可以换成其他字符,如:【?:abc】
* 测试用例:能 匹 配:/api ; /api/123 ; /api/abc ; /api/abc.html ; /api/abc/
不能匹配:/api/123/456 :即/api/之后只能再接一个参数
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/?:id", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项:【:id】前面没有了 ?
* 测试用例:能 匹 配:/api/123 ; /api/abc ; /api/abc.html ; /api/abc/
不能匹配:/api ; /api/123/456 :即/api/之后只能再接一个参数
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/:id", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项:【:id】前面没有了 ?
* 测试用例:能 匹 配:/api/123 ; /api/0
不能匹配:/api ; /api/123/456 ; /api/abc ; /api/123.html
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/:id:int", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项::id([0-9]+) 之中有个 + 号。有+号时表示可以是多位数字,无+号表示就只能匹配一位数字
* 测试用例:能 匹 配:/api/123 ; /api/0
不能匹配:/api ; /api/abc ; /api/123/456 :即/api/之后只能再接一个参数
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/:id([0-9]+)", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项::[\\w] 之中的w不能替换为别的字符
* 测试用例:能 匹 配:/api/123 ; /api/hezhixiong
不能匹配:/api ; /api/abc.html
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/:username([\\w]+)", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项:: :username:string表示 username为string型
* 测试用例:能 匹 配:/api/123 ; /api/hezhixiong
不能匹配:/api ; /api/abc.html
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/:username:string", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项::无
* 测试用例:能 匹 配:/api/123 ; /api/hezhixiong ; /api/abc.html ; /api/abc/123/efg/ddd
不能匹配:/api
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/*.*", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项::无
* 测试用例:能 匹 配:/api/123 ; /api/hezhixiong ; /api/abc.html ; /api/abc/123/efg/ddd
不能匹配:/api
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/*", &controllers.MainController{})
/**
* 正则路由实践
* 注意事项::无
* 测试用例:能 匹 配:/api/bei_123.html ; /api/bei_0.html
不能匹配:/api/bei_.html ; /api/bei_123 ; /api/bei_12a.html
* 输出结果:具体输出结果需要看第二个参数的Get()方法所指定的模板和数据。
*/
beego.Router("/api/bei_:id([0-9]+).html", &controllers.MainController{})
/**
* 自定义方法及RESTful规则的实践
*/
/**
* 自定义方法实践
* 注意事项:第三个参数"*:MyMethod"之中,不能有空格(如:"* : MyMethod"),否则编译报错
* 测试用例:客户端进行Get,Post,Put,Delete请求
* 输出结果:执行 MainController的MyMethod方法,不再执行RESTful的规则:即Get请求执行Get方法……
*/
beego.Router("/bei", &controllers.MainController{}, "*:MyMethod")
/**
* Get请求不再执行Get()函数,而是执行指定的MyGet()函数,没指定的其他请求(如Post),则按照RESTful规则执行
* beego.Router("/bei", &controllers.MainController{}, "get:MyGet")
*
* 多个 HTTP Method 指向同一个函数
* beego.Router("/bei", &controllers.MainController{}, "get,post:MyGetPost")
*
* 不同的 method 对应不同的函数,通过 ;进行分割
* beego.Router("/bei", &controllers.MainController{}, "get:GetFunc;post:PostFunc")
*
* 如果同时存在 * 和对应的 HTTP Method,那么优先执行 HTTP Method 的方法
* beego.Router("/bei", &controllers.MainController{}, "*:AllFunc;post:PostFunc")
*/
/**
* 自动路由
*/
/**
* 正则路由实践
* 注意事项:控制器的名称为:MainController,那么【main】为路径中的第一个参数
* 测试用例:路径为:/main/login 将会调用 MainController 中的Login()函数
路径为:/main/login/123 将会调用 MainController 中的Login()函数
路径为:/hello/login.htm 将会调用 MainController 中的Login()函数
路径为:/hello/login 不能调用 MainController 中的Login()函数
路径为:/hellologin 不能调用 MainController 中的Login()函数
* 输出结果:具体输出结果需要看控制器(MainController)的Login函数所指定的模板和数据。
*/
beego.AutoRouter(&controllers.MainController{}) // 把需要的路由注册到自动路由中
/**
* 注解路由
*/
/**
* 注解路由实践
* 注意事项:重要comments:// @router
* 测试用例:
* 输出结果:具体输出结果需要看控制器(MainController)的函数所指定的模板和数据。
*/
beego.Include(&controllers.MainController{})
/**
* namespace路由
*/
/**
* namespace路由实践
* 注意事项:必须要把NewNamespace的对象注册到AddNamespace中去,否则无效
* 测试用例:仅仅匹配:/aaa/go
* 输出结果:get请求的情况下,执行指定函数Login;其他HTTP method则按照RESTful规则
*/
ns_1 := beego.NewNamespace("aaa", beego.NSRouter("/go", &controllers.MainController{}, "get:Login"))
// beego.AddNamespace(ns_1)
/**
* 域名如果不是:127.0.0.1,则不可以匹配 /bbb/go
* 仅仅匹配:/bbb/go
*/
ns_2 := beego.NewNamespace("bbb",
beego.NSCond(func(ctx *context.Context) bool {
if ctx.Input.Domain() == "127.0.0.1" {
return true
}
return false
}),
beego.NSRouter("/go", &controllers.MainController{}, "get:Login"),
)
ns_3 := beego.NewNamespace("ccc",
beego.NSRouter("/go", &controllers.MainController{}, "get:Login"),
// 条件判断,如果为真,则可以匹配上下文的路由,如果为假,则上下文的路由都不能匹配
beego.NSCond(func(ctx *context.Context) bool {
if ctx.Input.Domain() == "127.0.0.1" {
return true
}
return false
}),
beego.NSRouter("php", &controllers.MainController{}),
beego.NSGet("java", func(ctx *context.Context) {
ctx.Output.Body([]byte("显示Get追加的内容"))
}),
// nasespace嵌套示例
beego.NSNamespace("room",
beego.NSCond(func(ctx *context.Context) bool {
// 如果子namespace的判断条件为假,那么仅仅是子namespace的url不能匹配,不影响夫namespace的匹配结果
if ctx.Input.Request.Method != "GET" {
return true
}
return false
}),
beego.NSRouter("/shanghai", &controllers.MainController{}), // 匹配地址:/ccc/room/shanghai
),
)
beego.AddNamespace(ns_1, ns_2, ns_3)
}