Swift使用URLSession請求數(shù)據(jù)、加載網(wǎng)絡(luò)圖片、上傳圖片

1惠奸、URLSession請求數(shù)據(jù)
func requestData(_ url: String , _ completionHandler: @escaping (_ result: NSDictionary) -> Void) {
    
    let url = URL(string: url)!
    var request = URLRequest(url: url)
    request.httpMethod = "GET"
    request.addValue(myUserAgent, forHTTPHeaderField: "User-Agent")
    
    UIApplication.shared.isNetworkActivityIndicatorVisible = true
    
    URLSession.shared.dataTask(with: request) { data, response, error in
        
        if error == nil && data != nil {
            UIApplication.shared.isNetworkActivityIndicatorVisible = false
            do {
                 completionHandler(try JSONSerialization.jsonObject(with: data!, options: []) as! NSDictionary)
            } catch  {
                print(#function)
            }
            return
        }
        
        }.resume()
}

使用方法:

requestData(url) { (dic) in
    DispatchQueue.main.async(execute: { 
           print(dic)
      })
 }

2、URLSession加載網(wǎng)絡(luò)圖片
func downloadImageToImageDictionary(_ imageFileName: String ,_ imageView: UIImageView,_ url: String)
{
        if let myImageInDictionary = myImageDictionary[imageFileName]{
        DispatchQueue.main.async() { () -> Void in
            imageView.image = myImageInDictionary
        }
    } else {
            URLSession.shared.dataTask(with: URL(string: url)!) { (data, response, error) in
            guard let data = data, error == nil else { return }
            DispatchQueue.main.async() { () -> Void in
                imageView.image = UIImage(data: data)
                if UIImage(data: data) != nil {
                    myImageDictionary.updateValue(UIImage(data: data)!, forKey: imageFileName)
                }
            }
            }.resume()
    }
    
}

使用方法:

downloadImageToImageDictionary(imagePath, imageView, imagePath)

3恰梢、URLSession上傳圖片
public func imageUploading(fileName:String, image:UIImage,_ completion:((NSDictionary?) -> Void)!) {
    
    let urlString = ""
    let url = URL(string: urlString)!
    var request:URLRequest = URLRequest(url: url, cachePolicy: NSURLRequest.CachePolicy.reloadIgnoringLocalCacheData, timeoutInterval: 20)

    var builder = myMultipartDataBuilder()
    builder.appendFormData("filedata",content: UIImageJPEGRepresentation(image, 1.0)!,fileName: filename, contentType: "image/jpeg")
    
    request.setMultipartBody(builder.build()!, boundary: builder.boundary)
    
    let task = URLSession.shared.dataTask(with: request as URLRequest, completionHandler: { data, response, error in
        if error != nil {
            completion(nil)
            return
        }
        do {
            completion(try JSONSerialization.jsonObject(with: data!, options: []) as? NSDictionary)
        } catch  {
            print("POST Error:")
            completion(nil)
        }
    })
    
    task.resume()
}

轉(zhuǎn)換成data格式

private let MultipartFormCRLF = "\r\n"
private let MutlipartFormCRLFData = MultipartFormCRLF.data(using: String.Encoding.utf8)!

public extension URLRequest {
    
    public mutating func setMultipartBody(_ data: Data, boundary: String) {
        
        self.httpMethod = "POST"
        self.setValue("application/x-www-form-urlencoded", forHTTPHeaderField: "Content-Type")
        self.httpBody = data
        self.setValue(String( data.count ), forHTTPHeaderField: "Content-Length")
        self.setValue("multipart/form-data; boundary=\(boundary)", forHTTPHeaderField: "Content-Type")
        self.setValue(myUserAgent, forHTTPHeaderField: "User-Agent")
    }
}


extension CharacterSet {
    
    static func MIMECharacterSet() -> CharacterSet {
        let characterSet = CharacterSet(charactersIn: "\"\n\r")
        return characterSet.inverted
    }
}


public struct myMultipartDataBuilder {
    
    var fields: [Data] = []
    public let boundary: String
    
    public init() {
        self.boundary = NSUUID().uuidString //"0xKhTmXbhgOuNdArY000" //NSUUID().uuidString
    }
    
    public func build() -> Data? {
        
        let data = NSMutableData()
        
        for field in self.fields {
            data.append(self.toData("--\(self.boundary)"))
            data.append(MutlipartFormCRLFData)
            data.append(field)
        }
        
        data.append(self.toData("--\(self.boundary)--"))
        data.append(MutlipartFormCRLFData)
        
        return (data.copy() as! Data)
    }

    mutating public func appendFormData(_ key: String, value: String) {
        let content = "Content-Disposition: form-data; name=\"\(encode(key))\""
        let data = self.merge([
            self.toData(content),
            MutlipartFormCRLFData,
            MutlipartFormCRLFData,
            self.toData(value),
            MutlipartFormCRLFData
            ])
        self.fields.append(data)
    }
    
    mutating public func appendFormData(_ name: String, content: Data, fileName: String, contentType: String) {
        
        let contentDisposition = "Content-Disposition: form-data; name=\"\(self.encode(name))\"; filename=\"\(self.encode(fileName))\""
        let contentTypeHeader = "Content-Type: \(contentType)"
        let data = self.merge([
            self.toData(contentDisposition),
            MutlipartFormCRLFData,
            self.toData(contentTypeHeader),
            MutlipartFormCRLFData,
            MutlipartFormCRLFData,
            content,
            MutlipartFormCRLFData
            ])
        self.fields.append(data)
    }

    fileprivate func encode(_ string: String) -> String {
        let characterSet = CharacterSet.MIMECharacterSet()
        return string.addingPercentEncoding(withAllowedCharacters: characterSet)!
    }
    
    fileprivate func toData(_ string: String) -> Data {
        return string.data(using: String.Encoding.utf8)!
    }
    
    fileprivate func merge(_ chunks: [Data]) -> Data {
        let data = NSMutableData()
        for chunk in chunks {
            data.append(chunk)
        }
        return data.copy() as! Data
    }
    
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末晨川,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子删豺,更是在濱河造成了極大的恐慌共虑,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,464評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件呀页,死亡現(xiàn)場離奇詭異妈拌,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評論 3 399
  • 文/潘曉璐 我一進(jìn)店門尘分,熙熙樓的掌柜王于貴愁眉苦臉地迎上來猜惋,“玉大人,你說我怎么就攤上這事培愁≈ぃ” “怎么了?”我有些...
    開封第一講書人閱讀 169,078評論 0 362
  • 文/不壞的土叔 我叫張陵定续,是天一觀的道長谍咆。 經(jīng)常有香客問我,道長私股,這世上最難降的妖魔是什么摹察? 我笑而不...
    開封第一講書人閱讀 59,979評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮倡鲸,結(jié)果婚禮上供嚎,老公的妹妹穿的比我還像新娘。我一直安慰自己峭状,他們只是感情好克滴,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著优床,像睡著了一般劝赔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上羔巢,一...
    開封第一講書人閱讀 52,584評論 1 312
  • 那天望忆,我揣著相機(jī)與錄音,去河邊找鬼竿秆。 笑死启摄,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的幽钢。 我是一名探鬼主播歉备,決...
    沈念sama閱讀 41,085評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼匪燕!你這毒婦竟也來了蕾羊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,023評論 0 277
  • 序言:老撾萬榮一對情侶失蹤帽驯,失蹤者是張志新(化名)和其女友劉穎龟再,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體尼变,經(jīng)...
    沈念sama閱讀 46,555評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡利凑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片哀澈。...
    茶點(diǎn)故事閱讀 40,769評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡牌借,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出割按,到底是詐尸還是另有隱情膨报,我是刑警寧澤,帶...
    沈念sama閱讀 36,439評論 5 351
  • 正文 年R本政府宣布适荣,位于F島的核電站现柠,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏束凑。R本人自食惡果不足惜晒旅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評論 3 335
  • 文/蒙蒙 一栅盲、第九天 我趴在偏房一處隱蔽的房頂上張望汪诉。 院中可真熱鬧,春花似錦谈秫、人聲如沸扒寄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽该编。三九已至,卻和暖如春硕淑,著一層夾襖步出監(jiān)牢的瞬間课竣,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評論 1 274
  • 我被黑心中介騙來泰國打工置媳, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留于樟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,191評論 3 378
  • 正文 我出身青樓拇囊,卻偏偏與公主長得像迂曲,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子寥袭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評論 2 361

推薦閱讀更多精彩內(nèi)容