2016-11-27 8 views
1

単純にデータをサーバーにポストするためのコードがあり、ポストリクエストが成功した場合はブール値successが返されますが、その前にブール値が返されているようですデータが処理される、私は何か間違っている?処理を終了する前に値を返すスウィフト関数

public func postRequest(rawText: String) -> Bool { 
    var success = true 
    let destUrl = "http://api.getquesto.com:8080/upload/" 
    var request = URLRequest(url: URL(string: destUrl)!) 
    request.httpMethod = "POST" 
    let postString = rawText 
    request.setValue("text/plain", forHTTPHeaderField: "Content-Type") 
// request.setValue("compute", forHTTPHeaderField: "Questo-Query") 
// request.setValue("Fuck you", forHTTPHeaderField: "quizTitle") 

    request.httpBody = postString.data(using: .utf8) 
    print(request.httpBody!) 
    let task = URLSession.shared.dataTask(with: request) { data, response, error in 
     guard let data = data, error == nil else {             // check for fundamental networking error 
      print("error=\(error)") 
      success = false 
      print(success) 

      return 
     } 

     if let httpStatus = response as? HTTPURLResponse, httpStatus.statusCode != 200 {   // check for http errors 
      print("statusCode should be 200, but is \(httpStatus.statusCode)") 
      print("response = \(response)") 
     } 

     let responseString = String(data: data, encoding: .utf8) 
     do { 
      if let json = try JSONSerialization.jsonObject(with: data, options: JSONSerialization.ReadingOptions(rawValue: UInt(0))) as? [String: Any] { 
       print("json \(json)") 
      } else { 
       print("can not cast data") 
       success = false 

      } 
     } catch let error { 
      print("cant parse json \(error)") 
      success = false 
      print(success) 

     } 

     print("responseString = \(responseString)") 
     let dataString = NSString(data: data, encoding: String.Encoding.utf8.rawValue) 
     //print(dataString) 
     //print("responseString = \(responseString)") 
     constantVariables.rawQuestionData = dataString as! String 
     let processedResults = dataString?.replacingOccurrences(of: "\\n", with: " ") 
     print("processed results = " + (processedResults! as String)) 
     let newArray = processedResults!.components(separatedBy: ", \"") 
     //print(newArray) 

     for index in 0...(newArray.count - 1) { 
      if index%2 == 0 { 
       constantVariables.questions.insert(newArray[index].replacingOccurrences(of: "\"", with: "").replacingOccurrences(of: "]", with: "").replacingOccurrences(of: "[", with: ""), at: index/2) 

       //  ConstantsArray.questionArray.append(newArray[index]) 
       //  print("question array: " + ConstantsArray.answerArray[index/2]) 
      }else{ 
       constantVariables.answers.insert(newArray[index].replacingOccurrences(of: "\"", with: "").replacingOccurrences(of: "]", with: "").replacingOccurrences(of: "[", with: ""), at: (index-1)/2) 

       //  ConstantsArray.questionArray.append(newArray[index]) 
       print("answer array: " + constantVariables.answers[(index-1)/2]) 

      } 
     } 
    } 
    task.resume() 
    print(success) 
    return success 
    } 
+2

'URLSessionDataTask'は非同期です。あなたが' resume() 'を呼び出すとコードは続行され、タスクは2つの並列スレッドで開始します。それを同期させたい場合は、次のようなコードで拡張を行います:http://stackoverflow.com/a/34308158/2122979 – Ossir

+0

もっと似た質問と回答:http://stackoverflow.com/questions/40810108/swift -http-request-use-urlsession、http://stackoverflow.com/questions/40811500/ios-swift-value-of-an-integer-is-not-being-saved、http://stackoverflow.com/questions/40756123/swift-ensure-urlsession-datatask-my-function-before-passing-res、http://stackoverflow.com/questions/40491502/swift-3-send-make-synchronous-http -request、... –

答えて

2

機能が直接非同期を作品dataTasksuccessの値を返すので、dataTasksuccessの値を編集するための解析を終了するまで、機能、すなわち、待つべきではありませんので、これが起こっている:return successが実行されますdataTaskの前には、successの値が編集されます。

Boolの代わりにcompletionクロージャを処理させることをお勧めします。あなたの関数はのようになります。

:スウィフト3では

public func postRequest(rawText: String, completion: @escaping (_ success: Bool) ->()) { 
    var success = true 
    let destUrl = "http://api.getquesto.com:8080/upload/" 
    var request = URLRequest(url: URL(string: destUrl)!) 
    request.httpMethod = "POST" 
    let postString = rawText 
    request.setValue("text/plain", forHTTPHeaderField: "Content-Type") 
    // request.setValue("compute", forHTTPHeaderField: "Questo-Query") 
    // request.setValue("Fuck you", forHTTPHeaderField: "quizTitle") 

    request.httpBody = postString.data(using: .utf8) 
    print(request.httpBody!) 
    let task = URLSession.shared.dataTask(with: request) { data, response, error in 
     guard let data = data, error == nil else {             // check for fundamental networking error 
      print("error=\(error)") 
      success = false 
      print(success) 

      return 
     } 

     if let httpStatus = response as? HTTPURLResponse, httpStatus.statusCode != 200 {   // check for http errors 
      print("statusCode should be 200, but is \(httpStatus.statusCode)") 
      print("response = \(response)") 
     } 

     let responseString = String(data: data, encoding: .utf8) 
     do { 
      if let json = try JSONSerialization.jsonObject(with: data, options: JSONSerialization.ReadingOptions(rawValue: UInt(0))) as? [String: Any] { 
       print("json \(json)") 
      } else { 
       print("can not cast data") 
       success = false 

      } 
     } catch let error { 
      print("cant parse json \(error)") 
      success = false 
      print(success) 

     } 

     print("responseString = \(responseString)") 
     let dataString = NSString(data: data, encoding: String.Encoding.utf8.rawValue) 
     //print(dataString) 
     //print("responseString = \(responseString)") 
     constantVariables.rawQuestionData = dataString as! String 
     let processedResults = dataString?.replacingOccurrences(of: "\\n", with: " ") 
     print("processed results = " + (processedResults! as String)) 
     let newArray = processedResults!.components(separatedBy: ", \"") 
     //print(newArray) 

     for index in 0...(newArray.count - 1) { 
      if index%2 == 0 { 
       constantVariables.questions.insert(newArray[index].replacingOccurrences(of: "\"", with: "").replacingOccurrences(of: "]", with: "").replacingOccurrences(of: "[", with: ""), at: index/2) 

       //  ConstantsArray.questionArray.append(newArray[index]) 
       //  print("question array: " + ConstantsArray.answerArray[index/2]) 
      }else{ 
       constantVariables.answers.insert(newArray[index].replacingOccurrences(of: "\"", with: "").replacingOccurrences(of: "]", with: "").replacingOccurrences(of: "[", with: ""), at: (index-1)/2) 

       //  ConstantsArray.questionArray.append(newArray[index]) 
       print("answer array: " + constantVariables.answers[(index-1)/2]) 

      } 
     } 

     completion(success) 
    } 
    task.resume() 
    print(success) 
} 

、あなたが@escapingを使用する必要があり、より多くの情報のために、あなたはthis answerをチェックすることをお勧めします。

呼び出し:

postRequest(rawText: "rawText", completion: { success in 
    print(success) 
}) 

さて、それはそれはパースだそれまではdataTask仕上がりを待つ必要があり、その後、completion内のコードが呼び出されます。

希望しました。

+0

ありがとうございました!これはうまくいった! –

関連する問題