美文网首页
swift网络请求与数据保存

swift网络请求与数据保存

作者: heigo | 来源:发表于2017-02-28 23:01 被阅读0次
  //首页加载的数据的迁移
class func loadHomeData(sinceId: Int64,maxId: Int64,finished: @escaping ([[String : Any]]?) -> ()) {
    let res = checkoutStatus(sinceId: sinceId, maxId: maxId)
    //if let result ',' 可以获取到赋值的结果
    if let result = res, result.count > 0 {
        //有缓存数据  返回缓存数据
        //TODO: 待返回
        finished(result)
        return
    }
    
    //没有缓存数据, 请求网络数据
    let urlString = "https://api.weibo.com/2/statuses/home_timeline.json"
    let parameters = ["access_token" : HMUserAccountViewModel.shared.access_token,
                      "max_id" : "\(maxId)",
        "since_id" : "\(sinceId)"]
    
    HMNetworkTools.shared.request(method: .GET, urlString: urlString, parameters: parameters, finished: { (responseObject,error) -> () in
        if error != nil {
            //告诉外界请求失败 在闭包中如何完成失败的回调
            //TODO: 完成失败的回调
            finished(nil)
            return
        }
        
        //成功
        let dict = responseObject as! [String : Any]
        //尝试转换为字典类型的数组
        guard let array = dict["statuses"] as? [[String : Any]] else {
            finished(nil)
            return
        }
        
        
        //回调的网络 请求的结果
        finished(array)
        //存储到本地
        cacheStauts(array: array)
    })
}



//1.检查本地是否有缓存数据
class func checkoutStatus(sinceId: Int64,maxId: Int64) -> [[String : Any]]? {
    //查询的sql
    
    guard let userId = HMUserAccountViewModel.shared.userAccount?.uid else {
        return nil
    }
    
    //会将数据库中所有的缓存数据都查找到
    var sql = "SELECT status FROM T_Status WHERE userId = \(userId) "
    //拼接sql
    //如果sinceId > 0 标识需要查找新数据
    if sinceId > 0 {
        //向上查找
        sql += "AND statusId > \(sinceId) "
    }
    
    if maxId > 0 {
        //向下查找
        sql += "AND statusId < \(maxId) "
    }
    
    //排序 降序
    sql += "ORDER BY statusId DESC "
    
    //限制条数
    sql += "LIMIT 100"
    
    print(sql)
    //实例化数据
    var array = [[String : Any]]()
    
    HMSQLiteTools.shared.queue.inDatabase { (db) in
        guard let res = db!.executeQuery(sql, withArgumentsIn: nil) else {
            //在闭包中不能够return
            return
        }
        //逐条获取数据
        while res.next() {
            //获取status 二进制数据
            let jsonData = res.data(forColumn: "status")
            //转换为json 字典
            let dict = try! JSONSerialization.jsonObject(with:jsonData!, options: [])
            array.append(dict as! [String : Any])
        }
    }
    
    return array
}

//2. 如果本地有缓存数据 就直接返回本地的缓存数据,给用户节省流量,让用户在没有网络的情况可以浏览之前的内容

//3. 没有缓存数据就请求网络数据 返回网络数据

//4. 获取网络数据之后就应该立即存储网络数据
/*
 statusId
 status
 userId
 */
class func cacheStauts(array: [[String : Any]]) {
    //获取userId
    guard let userId = HMUserAccountViewModel.shared.userAccount?.uid else {
        print("用户没有登录呢")
        return
    }
    
    //sql
    //如果在对应的主键下已经存在数据 就执行替换的操作
    let sql = "INSERT OR REPLACE INTO T_Status (statusId,status,userId) VALUES (?,?,?)"
    HMSQLiteTools.shared.queue.inTransaction { (db, rollback) in
        
        for item in array {
            let statusId = item["id"]!
            //数据库中能够存储的数据不能够是Foundation 需要将字典数据转换二进制数据存储到数据库中
            //如果是字典数据 在读取的时候会有问题
            let jsonData = try! JSONSerialization.data(withJSONObject: item, options: [])
            let res =  db!.executeUpdate(sql, withArgumentsIn: [statusId,jsonData,userId])
            if !res {
               //不成功就执行回滚
                rollback?.pointee = true
                return
            }
        }
    }
}

相关文章

网友评论

      本文标题:swift网络请求与数据保存

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