前言
在Toolbox章节我们已经讲了Vapor的几种模板,可以点击以上链接去看.
MySQL模板
创建基于API模板的Vapor项目
这篇文章我们来讲下,如何改造一个默认API模板成为一个MySQL模板
vapor new VaporTemplateMySQL
或者
vapor new VaporTemplateMySQL --template=api
都是创建基于API模板的hello项目
改造成MySQL模板
Package.swift
改完之后的文件看起来应该是这样的
import PackageDescription
let package = Package(
    name: "VaporTemplateMySQL",
    targets: [
        Target(name: "App"),
        Target(name: "Run", dependencies: ["App"]),
    ],
    dependencies: [
        .Package(url: "https://github.com/vapor/vapor.git", majorVersion: 2),
        //重点是把原来的fluent-provider换成下面这个
        .Package(url: "https://github.com/vapor/mysql-provider.git", majorVersion: 2)
    ],
    exclude: [
        "Config",
        "Database",
        "Localization",
        "Public",
        "Resources",
    ]
)
重要!!!
更改完Package.swift文件之后记得运行
swift package update命令,下载最新依赖包
Config+Setup.swift
在配置提供程序那行
	import FluentProvider
    /// Configure providers
    private func setupProviders() throws {
        try addProvider(FluentProvider.Provider.self)
    }
换成
	import MySQLProvider
    /// Configure providers
    private func setupProviders() throws {
        try addProvider(MySQLProvider.Provider.self)
    }
Config目录的配置文件
fluent.json
改完应该是这样的
{
    "driver": "mysql"
}
mysql.json
原有Config目录下没有这个文件,你需要新建这个文件
{
    "hostname": "你MySQL数据库的主机地址",
    "user": "你MySQL数据库的用户名",
    "password": "你MySQL数据库的密码",
    "database": "你MySQL数据库的数据库名字"
}
Route.swift
添加引入代码
import MySQLProvider
添加以下代码获取数据库数据(仅作为示例添加,可自行书写修改)
	get("userinfo") { req in
            let name = req.data["name"]
            if name == nil {
                return try JSON(node: [
                    "data":"",
                    "msg" : "用户名为空",
                    "state":0
                    ])
            }
	let mysqlDriver = try self.mysql()
            
    let result = try mysqlDriver.raw("select * from users where username='" + (name?.string)! + "';")
    let userinfo = result[0]
    return try JSON(node: [
                    "data":userinfo,
                    "state":1,
                    "msg":"请求成功"
                ])
        }
