iOS 9基本HTTP请求

时间:2015-10-25 05:32:22

标签: swift ios9 xcode7

我已经研究了最近几个小时,但在我的Swift应用程序中找不到适用于iOS 9的示例。我只想对网址“http://www.example.com”执行HTTP GET请求。该URL将返回将被解析的XML数据,但是现在我只想让HTTP GET命令运行。

我是Xcode的新手,但有一些编程背景,但无法弄清楚如何获取URL来执行GET命令

我有一个按钮,我希望它在按下按钮时运行HTTP GET请求。在线查看NSURLSession示例时,我找不到不会抛出语法错误的示例。任何帮助,将不胜感激。下面是我发现的一个,但它抛出了一堆错误。任何指导都将不胜感激。

import Foundation
import XCPlayground
func httpGet(request: NSURLRequest!, callback: (String, String?) -> Void) {
    var session = NSURLSession.sharedSession()
    var task = session.dataTaskWithRequest(request){
        (data, response, error) -> Void in
        if error != nil {
            callback("”, error.localizedDescription),
        } else {
            var result = NSString(data: data, encoding:
                NSASCIIStringEncoding)!
            callback(result, nil)
        }
    }
    task.resume()
}
var request = NSMutableURLRequest(URL: NSURL(string: “http://www.google.com")!)

httpGet(request){
    (data, error) -> Void in
    if error != nil {
        println(error)
    } else {
        println(data)
    }
}
XCPSetExecutionShouldContinueIndefinitely(continueIndefinitely: true)

2 个答案:

答案 0 :(得分:1)

清理后的代码示例的Swift 2再现可能如下所示:

import Foundation
import XCPlayground

func httpGet(request: NSURLRequest, callback: (String?, NSError?) -> Void) {
    let task = NSURLSession.sharedSession().dataTaskWithRequest(request) { data, response, error in
        guard error == nil && data != nil else {
            callback(nil, error)
            return
        }

        callback(String(data: data!, encoding: NSUTF8StringEncoding), nil)
    }
    task.resume()
}

let request = NSMutableURLRequest(URL: NSURL(string: "http://www.google.com")!)

httpGet(request) { string, error in
    guard error == nil && string != nil else {
        print(error?.localizedDescription)
        return
    }

    print(string!)
}

XCPlaygroundPage.currentPage.needsIndefiniteExecution = true

这修复了原始代码段中的明显错误(偶尔使用而不是";使用已弃用的println而不是{ {1}};第一次print调用后无关的,;添加一些丢失的可选解包;等等。)

这也解决了一些其他问题,即

  • 使用callback而不是String;
  • NSString的{​​{1}}参数可选(而不是在出现错误时返回String);
  • 我认为最好返回实际的callback对象,而不仅仅是本地化描述(在某些时候,您可能真的关心错误的""NSError
  • 使用Swift 2 code语句来防止发生的任何错误。

答案 1 :(得分:0)

这是我使用的 GET 方法:

func get(url : String, successHandler: (response: String) -> Void) {
    let url = NSURL(string: url)
    let request = NSMutableURLRequest(URL: url!);
    request.HTTPMethod = "GET"

    let task = NSURLSession.sharedSession().dataTaskWithRequest(request) {
        data, response, error in

        //in case of error
        if error != nil {
            return
        }

        let responseString : String = String(data: data!, encoding: NSUTF8StringEncoding)!
        successHandler(response: responseString)
    }
    task.resume();
}

由于您正在发出纯HTTP请求,因此您需要修改Info.plist文件。如果您的文件是从默认模板创建的,则在最后一个数组元素后面添加以下键(例如,在新的单个视图应用程序中)。

<key>NSAppTransportSecurity</key>
<dict>
    <key>NSAllowsArbitraryLoads</key>
    <false/>
    <key>NSExceptionDomains</key>
    <dict>
        <key>google.com</key>
        <dict>
            <key>NSIncludesSubdomains</key>
            <true/>
            <key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key>
            <true/>
            <key>NSTemporaryExceptionMinimumTLSVersion</key>
            <string>TLSv1.1</string>
        </dict>
    </dict>
</dict>

一种不太安全的方法,允许任意数量的域:

<key>NSAppTransportSecurity</key>
<dict>
  <key>NSAllowsArbitraryLoads</key>
      <true/>
</dict>

最后,您可以在viewDidLoad()函数中测试上述方法以及任何回调。我打电话给我的回叫updateWebview,但你当然可以打电话给你。

override func viewDidLoad() {
    super.viewDidLoad()
    let url = "http://www.google.com"
    get(url, successHandler: {(response) in self.updateWebview(response)});
}

func updateWebview(let html: String) {
    print(html)
}

使用带参数的 POST 的示例:

func post(url : String, params : String, successHandler: (response: String) -> Void) {
    let url = NSURL(string: url)
    let params = String(params);
    let request = NSMutableURLRequest(URL: url!);
    request.HTTPMethod = "POST"
    request.HTTPBody = params.dataUsingEncoding(NSUTF8StringEncoding)

    let task = NSURLSession.sharedSession().dataTaskWithRequest(request) {
        data, response, error in

        //in case of error
        if error != nil {
            return
        }

        let responseString : String = String(data: data!, encoding: NSUTF8StringEncoding)!
        successHandler(response: responseString)
    }
    task.resume();
}