基于Swift的Web框架Vapor2.0之MySQL模板

转载请附原文链接:http://blog.fandong.me/2017/08/13/iOS-Vapor-MySQL/

前言

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":"请求成功"
                ])
        }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,107评论 19 139
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,268评论 4 61
  • 编程是一项聪明人玩的游戏,它既是对智力的考验,也是对习惯的考验。拥有良好的编程习惯,也意味着你可以在相同或更短的时...
    编程狮W3Cschool阅读 380评论 0 6
  • 一.如果爱,那就请深爱,如果不爱,那就愉悦地分开,任何一种讲对错,讲值不值,都是对曾经美好的一种褻瀆。 我在朋友圈...
    一棵樹阅读 227评论 0 0
  • 她的身材比例真的非常好有腰有丰满的臀部脸蛋也不错唯一就是皮肤有点黑广东人的皮肤不过看上去属于比较健康的颜色好迷人啊...
    秋天别来阅读 230评论 0 0