Basic Routing
路由是Web框架最重要的部分之一,路由决定了哪些请求会得到响应。
Vapor包含了许多路由功能,比如builders、groups、collections。在本节中我们将介绍一些路由的基本知识。
Register
大部分基本的路由都包括方法、路径和闭包三个部分。
drop.get("welcome") { request in
return "Hello"
}
标准的HTTP请求方法包括:get、post、put、patch、delete和options
drop.post("form") { request in
return "Submitted with a POST request"
}
你也可以使用any
来匹配所有的方法。
Nesting
路径的嵌套(向URL添加 /
)只需要将路径用逗号隔开:
drop.get("foo", "bar", "baz") { request in
return "You requested /foo/bar/baz"
}
你也可以直接在参数中添加/
,但是逗号更容易输入,并且使用类型安全的路由参数工作得更好。
Alternate
使用alternate语法将Method
作为第一个参数也可以访问:
drop.add(.trace, "welcome") { request in
return "Hello"
}
如果你想动态注册路由或者是不经常使用的方法,就可以这样写。
Request
每一个路由都有一个单独的Request
, 它包含了所有导致闭包调用的请求相关的所有数据。
Response Representable
路由闭包返回的方法有三个:
Response
ResponseRepresentable
throw
Response
返回一个自定义的Response
:
drop.get("vapor") { request in
return Response(redirect: "http://vapor.codes")
}
这对于创建特殊响应(如重定向)非常有用。 对于你要向response中添加Cookie或其他的情况下也是很有用的。
Response Representable
在之前的例子中,String
可以作为路由闭包的返回值,是因为它遵守了ResponseRepresentable协议。
Vapor中默认遵守该协议的类型有:
- String
- Int
- JSON
- Model
drop.get("json") { request in
return try JSON(node: [
"number": 123,
"text": "unicorns",
"bool": false
])
}
如果你好奇
node:
是什么意思,可以读读这篇文章Node
Throwing
如果你无法返回响应,可以thow
一个遵守Error
协议的对象,Vapor中默认实现了一个异常的枚举类:Abort
。(abort中断的意思)
drop.get("404") { request in
throw Abort.notFound
}
你可以使用Abort
类自定义错误信息:
drop.get("error") { request in
throw Abort.custom(status: .badRequest, message: "Sorry 😱")
}
这些错误信息默认是在AbortMiddleware
中捕获的,然后被转换成如下的json响应:
{
error: true,
message: "<the message>"
}
如果你想重写事件,可以移除Droplet
middleware中的AbortMiddleware
,然后添加自定义的。
Fallback
Fallback路由允许你匹配多层嵌套。( “*” 相当于是通配某一路径下的所有路径)
app.get("anything", "*") { request in
return "Matches anything after /anything"
}
上面例子中可以匹配如下所有的路由:
- /anything
- /anything/foo
- /anything/foo/bar
- /anything/foo/bar/baz
- ...
<b>总结:</b>路由是个很重要的概念,他决定了你的访问地址、请求对应的响应。本篇文章介绍了Vapor中如何注册路由、路由的返回类型以及嵌套路由、通配路由等基础知识。
网友评论