IOS 16 封装网络请求和log打印

本文基于 IOS 14 封装网络请求框架 对网络请求框架Moya的二次封装,并实现log打印、loading提示等。

封装前接口请求

Swift 复制代码
let provider = MoyaProvider<DefaultService>()
 
// 广告列表
provider.rx.request(.ads(position: VALUE0))
            .asObservable()
            .mapString()
            .mapObject(ListResponse<Ad>.self)
            .subscribe { event in
                switch(event){
                case .next(let data):
                    print(data.data.data?[0].title!)
                case .error(let error):
                    print("error \(error)")
                case .completed:
                    print("completed")
                }
            }.disposed(by: rx.disposeBag)

每次请求接口都需要创建MoyaProvider对象,比较浪费资源,故使用单例进行封装,APP进程内只创建一个MoyaProvider对象进行复用。

封装网络请求仓库

封装DefaultRepository网络请求仓库,实现MoyaProvider对象复用和使用插件实现log打印和loading提示

创建单例

Swift 复制代码
class DefaultRepository{
    static let shared = DefaultRepository()
    
    private var provider : MoyaProvider<DefaultService>!

    /// 私有构造方法
    private init() {
        provider = MoyaProvider<DefaultService>()
    }
}

实现log打印

Swift 复制代码
    /// 私有构造方法
    private init() {
        //插件列表
        var plugins:[PluginType] = []
        if Config.DEBUG {
            //表示当前是调试模式
            //添加网络请求日志插件
            plugins.append(NetworkLoggerPlugin(configuration: NetworkLoggerPlugin.Configuration(logOptions: .verbose)))
        }
        
        provider = MoyaProvider<DefaultService>(plugins: plugins)
    }

实现loading提示

Swift 复制代码
    /// 私有构造方法
    private init() {
        //插件列表
        var plugins:[PluginType] = []
      
        //网络请求加载对话框
        let networkActivityPlugin =  NetworkActivityPlugin{ change, target in
            //changeType类型是NetworkActivityChangeType
            //通过它能监听到开始请求和结束请求

            //targetType类型是TargetType
            //就是我们这里的service
            //通过它能判断是那个请求
            if change == .began {
                //开始请求
                let targetType = target as! DefaultService
                
                switch(targetType){
                case .sheets,.register:
                    DispatchQueue.main.async {
                        //切换到主线程
                        SuperToast.showLoading()
                    }
                default:
                    break
                }
            } else {
                //结束请求
                DispatchQueue.main.async {
                    //切换到主线程
                    SuperToast.hideLoading()
                }
            }
        }
        
        
        plugins.append(networkActivityPlugin)
        
        provider = MoyaProvider<DefaultService>(plugins: plugins)
    }

实现接口封装

Swift 复制代码
    /// 歌单列表
    /// - Parameter size: <#size description#>
    /// - Returns: <#description#>
    func sheets(size:Int) -> Observable<ListResponse<Sheet>> {
        return provider.rx
            .request(.sheets(size: size))
            .asObservable()
            .mapString()
            .mapObject(ListResponse<Sheet>.self)
    }
    
    /// 歌单详情
    /// - Parameter data: <#data description#>
    /// - Returns: <#description#>
    func sheetDetail(_ data:String) -> Observable<DetailResponse<Sheet>> {
        return provider.rx
                .request(.sheetDetail(data: data))
                .asObservable()
                .mapString()
                .mapObject(DetailResponse<Sheet>.self)
    }

DefaultRepository类完整代码

Swift 复制代码
//
//  DefaultRepository.swift
//  网络请求仓库
//
//  Created by jin on 2024/8/27.
//

import Foundation

//导入响应式编程框架
import RxSwift

//导入JSON解析框架
import HandyJSON

//导入网络框架
import Moya

class DefaultRepository{
    static let shared = DefaultRepository()
    
    private var provider : MoyaProvider<DefaultService>!
    
    /// 歌单列表
    /// - Parameter size: <#size description#>
    /// - Returns: <#description#>
    func sheets(size:Int) -> Observable<ListResponse<Sheet>> {
        return provider.rx
            .request(.sheets(size: size))
            .asObservable()
            .mapString()
            .mapObject(ListResponse<Sheet>.self)
    }
    
    /// 歌单详情
    /// - Parameter data: <#data description#>
    /// - Returns: <#description#>
    func sheetDetail(_ data:String) -> Observable<DetailResponse<Sheet>> {
        return provider.rx
                .request(.sheetDetail(data: data))
                .asObservable()
                .mapString()
                .mapObject(DetailResponse<Sheet>.self)
    }
    
    /// 私有构造方法
    private init() {
        //插件列表
        var plugins:[PluginType] = []
        if Config.DEBUG {
            //表示当前是调试模式
            //添加网络请求日志插件
            plugins.append(NetworkLoggerPlugin(configuration: NetworkLoggerPlugin.Configuration(logOptions: .verbose)))
        }
        
        //网络请求加载对话框
        let networkActivityPlugin =  NetworkActivityPlugin{ change, target in
            //changeType类型是NetworkActivityChangeType
            //通过它能监听到开始请求和结束请求

            //targetType类型是TargetType
            //就是我们这里的service
            //通过它能判断是那个请求
            if change == .began {
                //开始请求
                let targetType = target as! DefaultService
                
                switch(targetType){
                case .sheets,.register:
                    DispatchQueue.main.async {
                        //切换到主线程
                        SuperToast.showLoading()
                    }
                default:
                    break
                }
            } else {
                //结束请求
                DispatchQueue.main.async {
                    //切换到主线程
                    SuperToast.hideLoading()
                }
            }
        }
        
        
        
        plugins.append(networkActivityPlugin)
        
        provider = MoyaProvider<DefaultService>(plugins: plugins)
    }
}

封装后接口使用

Swift 复制代码
    DefaultRepository.shared.sheets(size: 10)
            .subscribeSuccess { data in
                print(data)
            }.disposed(by: rx.disposeBag)
相关推荐
hurrycry_小亦8 小时前
苹果WWDC 2026前瞻:Ferret-Pro端侧大模型即将亮相|小亦之闻|AI 编程三日速递!(5月26日~5月28日)
macos·ios·wwdc
UTF_812 小时前
一次NSMutableAttributedString误用的思考
ios·面试·github
人月神话-Lee16 小时前
【图像处理】Core Image 与 GPU 渲染管线——让滤镜飞起来
图像处理·人工智能·ios·chatgpt·ai编程·swift·gpu
夏天的峰没有风20 小时前
Typora+gitcode+picgo搭建免费图床
开发语言·ios·swift
库奇噜啦呼20 小时前
【iOS】源码学习-分类、扩展、关联对象
学习·ios·分类
帅次1 天前
Android 17 开发者实战:核心更新与应用场景落地指南
android·java·ios·android studio·iphone·android jetpack·webview
人月神话Lee1 天前
【图像处理】Core Image 与 GPU 渲染管线——让滤镜飞起来
ios·ai编程·图像识别
帅次2 天前
讯飞与腾讯云:Android 实时语音识别服务对比选择
android·ios·微信小程序·小程序·android studio·android runtime
择势2 天前
用一套View代码,同时支持RTL和LTR布局混合排版
ios
游戏开发爱好者82 天前
iOS开发工具推荐:Xcode、AppCode、SwiftLint使用心得与效率提升
ide·vscode·macos·ios·个人开发·xcode·敏捷流程