swift3.0開發學習之網絡框架Alamofire4.1的使用

網絡層是我們在日常開發中必須用到的框架。Alamofire是在swift開發中比較常用的一個開源框架,本文就是介紹Alamofire的相關使用。

Alamofire框架的介紹和使用

一. 什么是Alamofire

(1)Alamofire 的前身是 AFNetworking。AFNetworking 是 iOS 和 OS X 上很受歡迎的第三方HTTP網絡基礎庫。
(2)其實 AFNetwork 的前綴 AF 便是 Alamofire 的縮寫。
(3)Swift發布后,AFNetworking的作者又用Swift語言寫了個相同功能的庫,這便是 Alamofire。
(4)Alamofire 本質是基于URLSession,并做了封裝。使用 Alamofire 可以讓我們網絡請求相關代碼(如獲取數據,提交數據,上傳文件,下載文件等)更加簡潔易用。

二. Alamofire的使用

1.Alamofire使用了步驟

我在使用這個框架的時候是用的cocoapods導入的方式,當然也可以手動導入,本人感覺使用cocoapods比較方便,下面就是介紹一下cocoapods導入該庫的方法:(如果有的同學想要知道手動導入的步驟,可以參考這鏈接Alamofire手動導入方法)

(1).更新cocoapods的版本

cocoapods的使用方法我想對于大多數開發者來說肯定是再熟悉不過了,這里就略過了,如果有什么疑問的地方可以去看一下我之前寫過的文章關于cocoapods的使用,或者查閱一些資料。這里我做了一些特殊的處理方法。如果我們直接使用之前版本安裝的cocoapods來更新Alamofire最新版本可能會更新失敗,這里我們需要把cocoapods的版本升級到1.1.0+的版本才可以。
首先提到的一點是,在xcode8之后的cocoapods的鏡像已經有taobao的gem源換成了ruby.china的gem源。但是我在更換了路徑之后還是失敗了很多次,最后就索性換成了 使用國內的spec鏡像就可以了!

 cd ~/.cocoapods/repos  
 git clone https://git.coding.net/CocoaPods/Specs.git master

如果顯示master文件存在可以在~/.cocoapods/repos 路徑下先把master文件刪除,在進行替換,不過這個過程比較緩慢,請耐心等待即可。
更換完路徑后,再使用:

sudo gem install cocoapods --pre

更新cocoapods的版本即可(可以參照這里的一篇文章點擊這里)

(2).更新完cocoapods版本之后就是用cocoapods更新Alamofire的最新版本即可。
2.Alamofire的功能特點

(1).鏈式的請求/響應方法
(1).URL / JSON / plist參數編碼
(2).上傳類型支持:文件(File )、數據(Data )、流(Stream)以及MultipartFormData
(3).支持文件下載,下載支持斷點續傳
(4).支持使用NSURLCredential進行身份驗證
(5).HTTP響應驗證
(6).TLS Certificate and Public Key Pinning
(7).Progress Closure & NSProgress

3.Alamofire的網絡請求

(1).get請求

 // get
    func GET_Request() {
        let parameters : [String : Any] = ["foo": "bar"]
        
        //1,responseJSON
        Alamofire.request(main_url, method: .get, parameters: parameters).responseJSON { (returnResult) in
             print("GET_Request --> GET 請求 --> returnResult = \(returnResult)")
            
        if let json = returnResult.result.value {
            print("firstMethod --> responseJSON --> \(json)")
            /*  返回請求地址、數據、和狀態結果等信息
             print("firstMethod --> responseJSON() --> \(returnResult.request!)")
             print("firstMethod --> responseJSON() --> \(returnResult.data!)")
             print("firstMethod --> responseJSON() --> \(returnResult.result)")
             */
        }
        }

(2).post請求

    // post
    func POST_Request(){

        
        //request(host_url, method:.post, parameters : parameters)
        
        let urlstring = "\(host_url)type=\(top)&key=\(appkey)"
        
        Alamofire.request(urlstring, method:.post).responseJSON { (returnResult) in
             print("POST_Request --> post 請求 --> returnResult = \(returnResult)")
//            switch returnResult.result.isSuccess {
//            case true:
//                print("數據獲取成功!")
//            case false:
//                print(returnResult.result.error ?? Error.self)
//            }
           
        }
    }    

(3).響應處理(Response Handling)
除了上面樣例使用的responseJSON(處理json類型的返回結果)外,Alamofire還提供了許多其他類型的響應處理方法:

response()  
responseData()  
responseString(encoding: NSStringEncoding)  
responseJSON(options:NSJSONReadingOptions)  
responsePropertyList(options: NSPropertyListReadOptions)
       //2,response()
//        Alamofire.request(main_url, method:.get, parameters: parameters).response { (response) in
//            print("response = \(response.response)")
//            print("data = \(response.data)")
//            print("error = \(response.error)")
//            
//            
//            if let data = response.data , let utf8string = String(data: data , encoding:.utf8) {
//                print("utf8string = \(utf8string)")
//            }
//            
//        }
        
        
        
        
        //3,responseData()
//        Alamofire.request(main_url, method: .get, parameters: parameters).responseData { (responseData) in
//            debugPrint("responseData : \(responseData)")
//            
//            if let data = responseData.data, let utf8string = String(data: data, encoding: .utf8) {
//                print("utf8string = \(utf8string)")
//            }
//            
//        }
        
        
        
//        //4,responseString
//        Alamofire.request(main_url, method: .get, parameters: parameters).responseString { (responseString) in
//            debugPrint("responseString() --> Sucess = \(responseString.result.isSuccess)")
//             debugPrint("responseString : \(responseString)")
//            
//            if let data = responseString.data , let utf8string = String(data: data, encoding: .utf8) {
//               print("utf8string = \(utf8string)")
//            }
//        }
        
        
        
        // 5. responsePropertyList()  下面解釋
        
        
        
        //6.在response方法中還有一個方法  參數:queue:請求隊列 --> 就是默認在主線程中執行~但是我們可以自定義調度隊列。
//        let customQueue = DispatchQueue.global(qos: .utility)
//        Alamofire.request(main_url, method: .get, parameters: parameters).responseJSON(queue: customQueue) { (returnResult) in
//            print("請求隊列 --> \(returnResult)")
//        }

(4)下載,上傳

//下載 上傳
    
    func downloadAnduploadMethod() {
        //下載文件
        Alamofire.download(host_img_url).responseJSON { (returnResult) in
            if let data = returnResult.result.value {
                let image = UIImage(data : data as! Data)
                print("\(image)")
            }else {
                print("download is fail")
            }
        }
        
        //還可以看下載進度
        Alamofire.download(host_img_url).downloadProgress { (progress) in
             print("download progress = \(progress.fractionCompleted)")
        }.responseJSON { (returnResult) in
            if let data = returnResult.result.value {
                let image = UIImage(data : data as! Data)
                print("\(image)")
            }else {
                print("download is fail")
            }
        }
    
    }
具體的代碼,參照這里demo

這里只是簡單的介紹一下方法,后續會繼續介紹一些功能使用,希望共同進步,大家一起加油!!!

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,572評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,071評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,409評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,569評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,360評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,895評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,979評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,123評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,643評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,559評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,742評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,250評論 5 356
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,981評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,363評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,622評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,354評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,707評論 2 370

推薦閱讀更多精彩內容