Swift 使用 AFNetworking

本文介绍了一个用Swift实现的网络请求封装类,支持GET和POST请求,并通过AFNetworking库进行网络通信。该封装类使用单例模式,简化了JSON数据的序列化与反序列化过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

创建 一个  NewworkingTools.swift  文件
import Foundation
import AFNetworking

//枚举定义请求方式
enum HTTPRequestType {
    case GET
    case POST
}

class NetworkManager: AFHTTPSessionManager {

    //单例
    static let shared : NetworkManager = {
        let tools = NetworkManager()
        tools.requestSerializer = AFJSONRequestSerializer()
        tools.responseSerializer = AFJSONResponseSerializer()
        tools.requestSerializer.setValue("application/json,text/html", forHTTPHeaderField: "Accept")
        tools.requestSerializer.setValue("application/json; charset=utf-8", forHTTPHeaderField: "Content-Type")
        return tools
    }()

    /// 封装GET和POST 请求
    ///
    /// - Parameters:
    ///   - requestType: 请求方式
    ///   - urlString: urlString
    ///   - parameters: 字典参数
    ///   - completion: 回调
    func request(requestType: HTTPRequestType, urlString: String, parameters: [String: AnyObject]?, completion: @escaping (AnyObject?) -> ()) {

        //成功回调
        let success = { (task: URLSessionDataTask, json: Any)->() in
            completion(json as AnyObject?)
        }

        //失败回调
        let failure = { (task: URLSessionDataTask?, error: Error) -> () in
            print("网络请求错误 \(error)")
            completion(nil)
        }

        if requestType == .GET {
            get(urlString, parameters: parameters, progress: nil, success: success, failure: failure)
        } else {
            post(urlString, parameters: parameters, progress: nil, success: success, failure: failure)
        }
    }
}

使用

   NetworkManager.shared.request(requestType: .GET, urlString: "https://******/login", parameters: ["account": "111111" as AnyObject, "password" : "111111" as AnyObject]) { (json) in
            print(json as Any)
        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值