基于Swift的Web框架Vapor2.0文档(翻译)Hello,World

转载请附原文链接:http://blog.fandong.me/2017/08/04/iOS-SwiftVaporWeb04/

前言

之前一直有做Java后台开发的兴趣,可是想到要看好多的Java教程,作为一个iOS开发者,我放弃了,
后来从朋友韩云智VL那里知道了这个框架,竟是用Swift写的,不得不说,它燃起了我的兴趣。
Vapor是一个基于Swift开发的服务端框架,可以工作于iOS,Mac OS,Ubuntu。
为了配合Swift部署到服务器,我把ECS的服务器系统改为Ubuntu16.04。

Vapor 2.0 - 文档目录
以下文字翻译自Vapor Docs/Getting started/Hello,World

Hello,World

这个章节需要你已经安装了Swift3.1以及Vapor工具箱并且确认他们正在工作

提示
如果你不想要使用工具箱,请移步手动指引

新工程

让我们开始常见一个叫“Hello,World的新工程”

vapor new Hello --template=api

如果你已经使用过其他网络框架之后,你会对Vapor的目录结构很熟悉。

Hello
├── Config
│   ├── app.json
│   ├── crypto.json
│   ├── droplet.json
│   ├── fluent.json
│   └── server.json
├── Package.pins
├── Package.swift
├── Public
├── README.md
├── Sources
│   ├── App
│   │   ├── Config+Setup.swift
│   │   ├── Controllers
│   │   │   └── PostController.swift
│   │   ├── Droplet+Setup.swift
│   │   ├── Models
│   │   │   └── Post.swift
│   │   └── Routes.swift
│   └── Run
│       └── main.swift
├── Tests
│   ├── AppTests
│   │   ├── PostControllerTests.swift
│   │   ├── RouteTests.swift
│   │   └── Utilities.swift
│   └── LinuxMain.swift
├── circle.yml
└── license

对于我们的Hello,World工程,我们将会关注Route.swift文件

Hello
└── Sources
    └── App
        └── Routes.swift

提示
vapor new这个命令会创建一个包含例子和描述怎么使用这个框架的新工程,如果你愿意你也可以删除它

代码

Droplet

在Routes.swift文件中看下面这行

func setupRoutes() throws

这是所有访问我们应用程序的路由都会添加的方法

路由

build方法的范围内,查找以下的陈述

get("plaintext"){ req in
    return "Hello,world!"
}

这行代码创建了一个新的路由,这个路由会匹配所有的到/plaintext的GET请求
所有的路由闭包都传递一个包含所请求的URI和发送的数据等信息的请求的实例
这个路由只是简单的返回了一个字符串,但是任何一个可以表示响应的都可以被返回,在指引的路由章节学习更多

提示
Xcode会自动完成添加外部类型信息到你的闭包的输入参数中,如果你愿意保持原有类型信息,在文件顶部添加import HTTP

编译&运行

Building

Swift最先进的编译器是使得Vapor变得很强大的重要部分,让我们动起来,确保你在工程的根目录,运行下面的程序进行编译

vapor build

笔记
vapor build会在后台运行swift build

Swift包管理器会在第一时间从git上下载相关联的依赖,接下来一起编译和链接这些依赖
当完成的时候你会看到Building Project[Done]

提示
如果你看到unable to execute command: Killed这条消息,你需要增加你的交换空间的大小,这只有在你运行在一个有限的内存空间的机器上才会出现

Release

在release模式下编译会消耗更多的时间,但是提升了体验

vapor build --release

Serving

运行如下命令启动这个服务

vapor run serve

你应该会看到Server starting....这条消息
你现在可以在浏览器访问localhost:8080/plaintext或者运行

curl localhost:8080/plaintext

笔记
指定一个端口号需要管理员权限,你可以通过运行sudo vapor run来获取权限,如果你决定运行在80之外的其他端口,请确保你的浏览器也按照这个端口进行访问

Hello,World

你应该可以在你的浏览器窗口中看到如下的输出

Hello,world!

成功
到现在,你喜欢上Vapor了吗?点击下面的按钮来star这个仓库帮助发扬光大

Github

生产环境

在生产环境运行服务会增强他的安全性和体验

vapor run serve --env=production

再生产环境,debug消息会静默,所以错误可以通过查看日志来发现

警告
如果你是在--releaseflag标记下编译的,确保你也在vapor run的时候添加上此flag,vapor run serve --env=production --release

更多关于部署代码的更多信息,请移步部署(Deploy)章节

你可能感兴趣的:(基于Swift的Web框架Vapor2.0文档(翻译)Hello,World)