美文网首页
Vapor 路由、中间件、 Auth用户权限。

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

作者: Vine_Finer | 来源:发表于2018-02-04 18:12 被阅读57次

路由、中间件、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)
}

相关文章

网友评论

      本文标题:Vapor 路由、中间件、 Auth用户权限。

      本文链接:https://www.haomeiwen.com/subject/nvzmzxtx.html