前言
上一篇我们初步了解了Droplet和Route,本篇中我们一起写一些简单的get和post请求,以及我总结的一些套路。因为本人也是初学,没有任何后端开发经验,所有难免出现错误,大虾们多多指正。
常见请求
get/post请求
返回字符串
1 | drop.get("get","string") { req in |
返回JSON
1 | drop.get("get","json") { req in |
获取request中数据
1 | drop.get("get","info") { req in |
post请求同上处理。
项目路由处理常见套路
单一文件
demo或者测试项目中业务逻辑很少,不需要统一管理时,所有的路由直接写main.swift
中就可以了。
如: main.swift
1 |
|
vapor模板中的实现
当直接使用vapor new Hello --template=api
创建一个名为“hello”的vapor默认的模板项目时,内部已经存在了部分样板代码。
具体就是通过给Config
、Droplet
添加extension,在extension中实现路由注册。具体代码参考Sources/App/Setup/
目录下Config+Setup.swift
和Droplet+Setup.swift
文件。
在Droplet+Setup.swift
实现一个setup
方法去注册路由
1 | extension Droplet { |
工具类统一注册路由
通过一个工具类如:RouteTool、Router 等等(命名随意),来统一注册路由,以MVC的方式搭建项目。
首先在main.swift
中,我们定义全局变量api
、v1
、v2
等(根据实际需求)管理路由组。如:
1 | let config = try Config() |
然后如上述代码中RouteTool.setUp()
,我们创建一个路由工具RouteTool
,并为其实现一个setUp
方法来为不同的控制器统一注册路由。示例:
1 |
|
然后我们在具体的控制器里,完成路由注册、数据请求的具体实现。比如我们创建SignUpController,用来处理用户注册的业务。
在SignUpController.swift
中,我们实现处理请求。方法内部的业务代码此处使用...
省略,并非本篇重点。
1 | class SignController { |
通过RouteCollection协议来注册路由组
同样的,我们使用上一节中的SignController
作代码示例。遵守RouteCollection
协议并实现func build(_ builder: RouteBuilder)
协议方法。
1 | class SignController: RouteCollection { |
这时候我们就可以在main.swift
中通过collection(<#T##c: (EmptyInitializable & RouteCollection).Protocol##(EmptyInitializable & RouteCollection).Protocol#>)
来注册路由组了。
1 | let config = try Config() |
我们也可以为控制器实现一个extension并遵守EmptyInitializable
协议,这样做的目的是注册路由时我们无需实例化该控制器。
1 | extension SignController: EmptyInitializable { } |
此时我们在以上注册路由组的示例代码中就不需要实例化SignController了。
1 | drop.collection(SignController.self) |
最后
本篇是我在阅读文档和其他开源项目时总结的一些小套路,毕竟我也没有后端开发经验,文中若出现错误,欢迎批评指正。