Exit, ExitAllExitHook

  1. Exit: 仅退出当前执行的逻辑方法,不退出后续的请求流程,可用于替代 return
  2. ExitAll: 强行中断当前执行流程,当前执行方法的后续逻辑以及后续所有的逻辑方法将不再执行,常用于权限控制。
  3. ExitHook: 当路由匹配到多个 HOOK 方法时,默认是按照路由匹配优先级顺序执行 HOOK 方法。当在 HOOK 方法中调用 ExitHook 方法后,后续的 HOOK 方法将不会被继续执行,作用类似 HOOK 方法覆盖。
  4. 这三个退出函数仅在服务函数和 HOOK 事件回调函数中有效,无法控制中间件的执行流程。

由于 ExitAllExitHook 方法在应用层比较少用,因此这里仅介绍 Exit 方法的使用。

数据返回-Exit控制 - 图1提示

Exit* 流程退出特性底层采用的是 panic...recover... 机制来实现的,CPU执行损耗大约几十纳秒( ns),通过极少的运行时开销来提高易用性。

Exit 返回方法

  1. package main
  2. import (
  3. "github.com/gogf/gf/v2/frame/g"
  4. "github.com/gogf/gf/v2/net/ghttp"
  5. )
  6. func main() {
  7. s := g.Server()
  8. s.BindHandler("/", func(r *ghttp.Request) {
  9. if r.Get("type").Int() == 1 {
  10. r.Response.Writeln("john")
  11. }
  12. r.Response.Writeln("smith")
  13. })
  14. s.SetPort(8199)
  15. s.Run()
  16. }

执行后,我们访问 http://127.0.0.1:8199/?type=1 ,可以看到页面输出了:

  1. smith

我们将以上代码稍微调整一下:

  1. package main
  2. import (
  3. "github.com/gogf/gf/v2/frame/g"
  4. "github.com/gogf/gf/v2/net/ghttp"
  5. )
  6. func main() {
  7. s := g.Server()
  8. s.BindHandler("/", func(r *ghttp.Request) {
  9. if r.Get("type").Int() == 1 {
  10. r.Response.Writeln("john")
  11. r.Exit()
  12. }
  13. r.Response.Writeln("smith")
  14. })
  15. s.SetPort(8199)
  16. s.Run()
  17. }

执行后,我们再次访问 http://127.0.0.1:8199/?type=1 ,可以看到页面输出了:

此外, Response 对象中提供了很多 Write*Exit 的方法,表示输出内容后立即调用 Exit 方法退出当前服务方法。