2016-09-15 33 views
6

Zaktualizowałem do najnowszej wersji Xcode (8) i po aktualizacji kodu do Swift 3, Alamofire nagle przestaje działać i rzuca dużo błędów.Alamofire w Swift 3 z iOS 8

Po wielu badaniach, stwierdziłem, że Alamofire dla Swift 3 jest kompatybilny z iOS9 +, więc teraz muszę znaleźć inny, który działa z iOS8 +.

Czy wiesz, w jaki sposób mogę wykonać tę samą funkcję, co Alamofire dla iOS8?

Odpowiedz

2

Nie znalazłem "prawdziwej" alternatywy dla Alamofire dla iOS 8, więc próbowałem użyć URLRequest z samego Swift firmy Apple.

Więc tutaj jest przykładem I wreszcie po wypróbowaniu i próbując (nawet bez SwiftyJSON):

func searchPosts() -> [Post] { 
    var request = URLRequest(url: URL(string: "https://www.mywebsite.com/searchPosts.php")!) 
    request.httpMethod = "POST" 
    let postString = "" 
    request.httpBody = postString.data(using: .utf8) 
    request.addValue("application/json", forHTTPHeaderField: "Content-Type") 
    request.addValue("application/json", forHTTPHeaderField: "Accept") 

    let task = URLSession.shared.dataTask(with: request) { data, response, error in 

     if let httpStatus = response as? HTTPURLResponse, httpStatus.statusCode != 200 { 
      print(httpStatus.statusCode) 
      self.showError() 
     } else { 
      do { 
       self.listPosts = [Post]() 
       // Convert NSData to Dictionary where keys are of type String, and values are of any type 
       let json = try JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.mutableContainers) as! [String:AnyObject] 

       for field in json["posts"] as? [AnyObject] ?? [] { 

        // Create "Post" object 
        let post = Post(
         id: (field["id"])! as! String, 
         title: (field["title"] as! String), 
         alias: (field["alias"] as! String), 
         catid: (field["catid"] as! String), 
         catname: (field["catname"] as! String), 
         date: (field["date"] as! String), 
         image: (field["image"] as! String), 
         introtext: (field["introtext"] as! String), 
         fulltext: (field["fulltext"] as! String) 
        ) 
        self.listPosts.append(post) 
       } 

       DispatchQueue.main.async { 
        self.tableView.reloadData() 
       } 
      } catch { 
       self.showError() 
      } 
     } 
    } 

    task.resume() 

    return listPosts 
} 

Mam nadzieję, że może to pomóc innym deweloperom. Będę bardzo wdzięczny, jeśli ktoś znajdzie inne możliwe rozwiązanie tego problemu.

Pozdrowienia

+1

Pewnym rozwiązaniem mogłoby być wykorzystanie AFNetworking (objective-c). Co jest dość łatwe w użyciu również w szybkim tempie. (Aby zainstalować, patrz http://www.davidebettio.com/use-afnetworking-with-swift/) – Olof