Swift-網(wǎng)絡請求

我的驛站
常用網(wǎng)絡請求的三種方式,使用AFNetworking請求,與OC相比只是語法不同;使用Alamofire,采用鏈式編程的思想,與AFN是統(tǒng)一團隊開發(fā);而Moya是對Alamofire的高度封裝,使用簡單(推薦)

AFNetworking

cocoapods導入AFNetworking,創(chuàng)建橋接文件,#import "AFNetworking.h",
創(chuàng)建NetworkManager繼承至AFHTTPSessionManager。

import UIKit
// 枚舉 (可以是任意類型)
enum NetworkMethod {
    case GET
    case POST
}
class NetworkManager: AFHTTPSessionManager {
    // 創(chuàng)建單利 (計算型屬性)
    static var sharedManager: NetworkManager {
        let tool = NetworkManager()
        tool.responseSerializer.acceptableContentTypes?.insert("application/json")
        tool.requestSerializer.timeoutInterval = 10
        return tool
    }
}
extension NetworkManager{
    // 設置默認get請求
    func request(method: NetworkMethod = .GET ,urlString: String,parameters: Any?,requestSuccess:@escaping (_ json: Any?)->(),requestFailure:@escaping (_ error: Error)->()) {
        // 定義閉包
        let success = {(task: URLSessionDataTask, json: Any)->() in
            requestSuccess(json)
        }
        let failure = {(tasks: URLSessionDataTask?, error: Error)->() in
            requestFailure(error)
        }
        if method == .GET {
            get(urlString, parameters: parameters, progress:nil, success: success, failure: failure)
        }
        if method == .POST {
            post(urlString, parameters: parameters, progress: nil, success: success, failure: failure);
        }
    }
}

使用方式

    func AFNetworkingRequest() {
        NetworkManager.sharedManager.request(method: .GET, urlString: "https://httpbin.org/get", parameters: nil, requestSuccess: { (responseObject) in
            print("AFN網(wǎng)絡請求成功: \(responseObject ?? "")")
        }) { (error) in
            print("AFN網(wǎng)絡請求失敗: \(error)")
        }

Alamofire

cocoapods導入Alamofire;完全是用swift語言寫的,使用方式有很多種,通常會自己簡單封裝個工具類,這里只是簡單介紹下

    func AlamofireGetRequest() {
        Alamofire.request("https://httpbin.org/get", method: .get, parameters: nil, encoding: URLEncoding.default, headers: nil).responseJSON { (response) in
            if (response.error == nil){
                print("Alamofire請求成功:\(response.result.value ?? "")")
            }else{
                print("Alamofire請求失敗:\(response.error ?? "" as! Error)")
            }
        }
    }
    func AlamofirePostRequest() {
        let dic: [String: String] = ["key1": "value1"] // 參數(shù)
        // JSONEncoding.prettyPrinted 是提交json
        Alamofire.request("https://httpbin.org/post", method: .post, parameters: dic, encoding: URLEncoding.default, headers: nil).responseJSON { (response) in
            if response.error == nil {
                print("Post 請求成功:\(response.result.value ?? "")")
            }else{
                print("Post 請求失?。篭(response.error ?? "" as! Error)")
            }
        }
    }

Moya

  • 首先我們定義一個 provider,即請求發(fā)起對象。往后我們如果要發(fā)起網(wǎng)絡請求就使用這個 provider。
  • 接著聲明一個 enum 來對請求進行明確分類,這里我們定義兩個枚舉值分別表示獲取頻道列表、獲取歌曲信息。
  • 最后讓這個 enum 實現(xiàn) TargetType 協(xié)議,在這里面定義我們各個請求的 url、參數(shù)、header 等信息。
import Foundation
import Moya
 
//初始化豆瓣FM請求的provider
let DouBanProvider = 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
    }
     
    //請求任務事件(這里附帶上參數(shù))
    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
        }
    }
     
    //是否執(zhí)行Alamofire驗證
    public var validate: Bool {
        return false
    }
     
    //這個就是做單元測試模擬的數(shù)據(jù),只會在單元測試文件中有作用
    public var sampleData: Data {
        return "{}".data(using: String.Encoding.utf8)!
    }
     
    //請求頭
    public var headers: [String: String]? {
        return nil
    }
}

使用

    //使用我們的provider進行網(wǎng)絡請求(獲取頻道列表數(shù)據(jù))
        DouBanProvider.request(.channels) { result in
            if case let .success(response) = result {
                //解析數(shù)據(jù)
                let data = try? response.mapJSON()
                let json = JSON(data!)
                self.channels = json["channels"].arrayValue
                 
                //刷新表格數(shù)據(jù)
                DispatchQueue.main.async{
                    self.tableView.reloadData()
                }
            }
        }
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容