美文网首页
Swift-网络请求Moya

Swift-网络请求Moya

作者: 物非0人非 | 来源:发表于2022-05-29 21:08 被阅读0次

前言

Moya简单使用:

一:Moya的一个简单工具类
//
//  DouBanAPI.swift
//  hangge_1797
//
//  Created by hangge on 2017/9/19.
//  Copyright © 2017年 hangge.com. All rights reserved.
//

import Foundation
import Moya

//初始化豆瓣FM请求的provider
let Provider = MoyaProvider<DouBan>()

/** 下面定义豆瓣FM请求的endpoints(供provider使用)**/

//请求分类
public enum DouBan {
    case channels  //获取频道列表
    case playlist(String) //获取歌曲
}

//请求配置
extension DouBan: TargetType {
    //服务器地址
    public var baseURL: URL {
        switch self {
        case .channels:
            return URL(string: "https://www.douban.com")!
        case .playlist(_):
            return URL(string: "https://douban.fm")!
        }
    }
    
    //各个请求的具体路径
    public var path: String {
        switch self {
        case .channels:
            return "/j/app/radio/channels"
        case .playlist(_):
            return "/j/mine/playlist"
        }
    }
    
    //请求类型
    public var method: Moya.Method {
        return .get
    }
    
    //请求任务事件(这里附带上参数)
    public var task: Task {
        switch self {
        case .playlist(let channel):
            var params: [String: Any] = [:]
            params["channel"] = channel
            params["type"] = "n"
            params["from"] = "mainsite"
            return .requestParameters(parameters: params,
                                      encoding: URLEncoding.default)
        default:
            return .requestPlain
        }
    }
    
    //是否执行Alamofire验证
    public var validate: Bool {
        return false
    }
    
    //这个就是做单元测试模拟的数据,只会在单元测试文件中有作用
    public var sampleData: Data {
        return "{}".data(using: String.Encoding.utf8)!
    }
    
    //请求头
    public var headers: [String: String]? {
        return nil
    }
}

二:具体使用

//
//  ViewController.swift
//  hangge_1797
//
//  Created by hangge on 2017/9/19.
//  Copyright © 2017年 hangge.com. All rights reserved.
//

import UIKit
import SwiftyJSON

class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
    
    //显示频道列表的tableView
    var tableView:UITableView!
    
    //频道列表数据
    var channels:Array<JSON> = []
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        //创建表视图
        self.tableView = UITableView(frame:self.view.frame, style:.plain)
        self.tableView!.delegate = self
        self.tableView!.dataSource = self
        
        //创建一个重用的单元格
        self.tableView!.register(UITableViewCell.self,
                                 forCellReuseIdentifier: "SwiftCell")
        self.view.addSubview(self.tableView!)
        
        //使用我们的provider进行网络请求(获取频道列表数据)
        Provider.request(.channels) { result in
            if case let .success(response) = result {
               
                /*
                 switch result {
                 case .success(let responseData):
                 if let response = JSONResponseFormatter(responseData.data) {
                 print(response)
                 if let status = response["state"] as? Int {
                 completion(.success(status == 1 ? true : false))
                 }
                 }
                 case .failure(_):
                 self.failureAction(error: .server)
                 completion(.failure(.server))
                 }
                 
                 */


                //解析数据
                let data = try? response.mapJSON()
                let json = JSON(data!)
                self.channels = json["channels"].arrayValue
                print("请求成功+++++:\(String(describing: data))" )
                //刷新表格数据
                DispatchQueue.main.async{
                    self.tableView.reloadData()
                }
            }
        }
    }
    
    //返回表格分区数
    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    
    //返回表格行数(也就是返回控件数)
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return channels.count
    }
    
    //创建各单元显示内容(创建参数indexPath指定的单元)
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath)
    -> UITableViewCell {
        
        //为了提供表格显示性能,已创建完成的单元需重复使用
        let identify:String = "SwiftCell"
        let cell = tableView.dequeueReusableCell(
            withIdentifier: identify, for: indexPath)
        cell.accessoryType = .disclosureIndicator
        
        //设置单元格内容
        cell.textLabel?.text = channels[indexPath.row]["name"].stringValue
        return cell
    }
    
    //处理列表项的选中事件
    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        
        //获取选中项信息
        let channelName = channels[indexPath.row]["name"].stringValue
        let channelId = channels[indexPath.row]["channel_id"].stringValue
        
        //使用我们的provider进行网络请求(根据频道ID获取下面的歌曲)
        Provider.request(.playlist(channelId)) { result in
            if case let .success(response) = result {
                //解析数据,获取歌曲信息
                let data = try? response.mapJSON()
                let json = JSON(data!)
                let music = json["song"].arrayValue[0]
                let artist = music["artist"].stringValue
                let title = music["title"].stringValue
                let message = "歌手:\(artist)\n歌曲:\(title)"
                 /*
                switch result {
                 case .success(let responseData):
                 if let response = JSONResponseFormatter(responseData.data) {
                 print(response)
                 if let status = response["state"] as? Int {
                 completion(.success(status == 1 ? true : false))
                 }
                 }
                 case .failure(_):
                 self.failureAction(error: .server)
                 completion(.failure(.server))
                 }
                 
                 */
                //将歌曲信息弹出显示
                self.showAlert(title: channelName, message: message)
            }
        }
    }
    
    //显示消息
    func showAlert(title:String, message:String){
        let alertController = UIAlertController(title: title,
                                                message: message, preferredStyle: .alert)
        let cancelAction = UIAlertAction(title: "确定", style: .cancel, handler: nil)
        alertController.addAction(cancelAction)
        self.present(alertController, animated: true, completion: nil)
    }
    
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }
}

相关文章

网友评论

      本文标题:Swift-网络请求Moya

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