Vapor 路由、中间件、 Auth用户权限。

路由、中间件、Auth用户权限。

这个本来需要分开写的但是,本人并没有理解透、所以这里就贴一些官方文档。以后可能会更新。如果有感觉自己写的好的我可以再这里添链接。

路由 Routing

基础路由

  • Routing is one of the most critical parts of a web framework. The router decides which requests get which responses.

  • 路由是Web框架中最重要的部分之一。 路由器决定哪些请求得到哪些响应。

  • Vapor has a plethora of functionality for routing including route builders, groups, and collections. In this section, we will look at the basics of routing.

  • Vapor具有很多的路由功能,包括路由builders,组和集合。 在本节中,我们将看看路由的基础知识。

注册

drop.get("welcome") { request in
    return "Hello"
}

嵌套、多重路由

drop.get("foo", "bar", "baz") { request in
    return "You requested /foo/bar/baz"
}

重定向

drop.get("vapor") { request in
    return Response(redirect: "http://vapor.codes")
}

响应类型(Response Representable)

drop.get("json") { request in
    var json = JSON()
    try json.set("number", 123)
    try json.set("text", "unicorns")
    try json.set("bool", false)
    return json
}

响应失败

drop.get("404") { request in
    throw Abort(.notFound)
}

drop.get("error") { request in
    throw Abort(.badRequest, reason: "Sorry 😱")
}

Fallback

app.get("anything", "*") { request in
    return "Matches anything after /anything"
}

  • Fallback routes allow you to match multiple layers of nesting slashes.

  • 回退路线允许您匹配多个嵌套斜杠层。

  • For example, the above route matches all of the following and more:

  • 例如,上面的路线匹配以下所有内容:

  • /anything

  • /anything/foo

  • /anything/foo/bar

  • /anything/foo/bar/baz

参数 Routing Parameters

  • This creates a route that matches users/:id where the :id is an Int. Here's what it would look like using manual route parameters.

  • 这将创建一个匹配 users /:id的路由:id是一个Int。 这是使用手动路由参数的样子。

drop.get("users", ":id") { request in
    guard let userId = request.parameters["id"]?.int else {
        throw Abort.badRequest
    }

    return "You requested User #\(userId)"
}

Parameterizable(可参数化的)

  • Any type conforming to Parameterizable can be used as a parameter. By default, all Vapor Models conform.
  • 大致就是能直接获得一个Model对象
drop.get("users", User.parameter) { req in
    let user = try req.parameters.next(User.self)

    return "You requested \(user.name)"
}

Route Groups (路由组)

Group

drop.group("v1") { v1 in
    v1.get("users") { request in
        // get the users
    }
}

Grouped

let v1 = drop.grouped("v1")
v1.get("users") { request in
    // get the users
}

Middleware (中间件)

drop.group(AuthMiddleware()) { authorized in 
    authorized.get("token") { request in
        // has been authorized
    }
}

Host

drop.group(host: "vapor.codes") { vapor in
    vapor.get { request in
        // only responds to requests to vapor.codes
    }
}

Chaining 链式调用

drop.grouped(host: "vapor.codes").grouped(AuthMiddleware()).group("v1") { authedSecureV1 in
    // add routes here
}

Route Collections

Route collections allow multiple routes and route groups to be organized in different files or modules.

路由集合允许将多个路由和路由组组织在不同的文件或模块中。

Example

import Vapor
import HTTP
import Routing

class V1Collection: RouteCollection {
    func build(_ builder: RouteBuilder) {
        let v1 = builder.grouped("v1")
        let users = v1.grouped("users")
        let articles = v1.grouped("articles")

        users.get { request in
            return "Requested all users."
        }

        articles.get(Article.init) { request, article in
            return "Requested \(article.name)"
        }
    }
}
  • 调用如下
let v1 = V1Collection()
drop.collection(v1)

Empty Initializable

  • You can add EmptyInitializable to your route collection if it has an empty init method. This will allow you to add the route collection via its type name.
class V1Collection: RouteCollection, EmptyInitializable {
    init() { }
    ...
  • 现在我们可以这样初始化进行调用
drop.collection(V1Collection.self)

中间件 Middleware

https://docs.vapor.codes/2.0/http/middleware/

Middleware

  • Middleware is an essential part of any modern web framework. It allows you to modify requests and responses as they pass between the client and your server.

  • 中间件是任何现代Web框架的重要组成部分。 它允许您在客户端和服务器之间传递请求和响应。

  • You can imagine middleware as a chain of logic connecting your server to the client requesting your web app.

  • 您可以将中间件想象为连接您的服务器和请求您的Web应用程序的客户端的逻辑链。

Version Middleware

  • As an example, let's create a middleware that will add the version of our API to each response. The middleware would look something like this:

  • 作为一个例子,我们来创建一个中间件,将我们的API版本添加到每个响应中。 中间件看起来像这样:

import HTTP

final class VersionMiddleware: Middleware {
    func respond(to request: Request, chainingTo next: Responder) throws -> Response {
        let response = try next.respond(to: request)

        response.headers["Version"] = "API v1.0"

        return response
    }
}
  • 使用的话大致如下
import Vapor

let config = try Config()

config.addConfigurable(middleware: VersionMiddleware(), name: "version")

let drop = try Droplet(config)

Auth用户认证 HTTP Session Validation Auth

HTTP https://docs.vapor.codes/2.0/http/package/

这一节是Web服务器的核心、比如响应头、认证、跨域、Session等等。

Auth https://docs.vapor.codes/2.0/auth/package/

  • 使用Auth
import PackageDescription

let package = Package(
    name: "Project",
    dependencies: [
        .Package(url: "https://github.com/vapor/vapor.git", majorVersion: 2),
        .Package(url: "https://github.com/vapor/auth-provider.git", majorVersion: 1)
    ],
    exclude: [ ... ]
)

对于持久化认证

1、需要 SessionPersistable

let memory = MemorySessions()
let sessionsMiddleware = SessionsMiddleware(memory)

2、 需要 Persist

let persistMiddleware = PersistMiddleware(User.self)

  • Authentication
let passwordMiddleware = PasswordAuthenticationMiddleware(User.self)
  • Droplet
import Vapor
import Sessions
import AuthProvider

let drop = try Droplet()

let authed = drop.grouped([sessionsMiddleware, persistMiddleware, passwordMiddleware])

  • 返回已经认证的用户
authed.get("me") { req in
    // return the authenticated user
    return try req.auth.assertAuthenticated(User.self)
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352