来自HTTPS URLSession.dataTask的0字节数据

时间:2018-11-08 15:18:02

标签: ios swift https tls1.2 nsurlsessiondatatask

我正在尝试从URL检索一些JSON数据,但是每次数据中它都返回0字节。我检查了几个不同的SO帖子,似乎没有一个与我从服务器获取数据的确切问题完全匹配的问题,实际上是使用TLS 1.2的HTTPS。因此,我认为不需要添加任何内容,尽管我可能是错的。

这是我的代码:

var tournaments: [Tournament] = []

/// Base API URL
let baseURL: String = "https://www.burningmeter.com/tournaments.json?page=1"

// ...

func retrieveAPIData() {
    // Build the API string
    var request: URLRequest = URLRequest(url: URL(string: baseURL)!)
    request.cachePolicy = URLRequest.CachePolicy.reloadIgnoringLocalCacheData
    request.addValue("application/json; charset=utf-8", forHTTPHeaderField: "Content-Type")
    request.httpMethod = "GET"

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

        // Did we get an error?
        guard error == nil else {
            print(error!)
            return
        }

        guard let json = data else {
            print("No data")
            return
        }

        guard json.count == 0 else {
            print("Zero bytes of data")
            return
        }

        let jsonDecoder = JSONDecoder()
        let tournaments = try! jsonDecoder.decode(TournamentPage.self, from: json)

        // We got our values, let's go
        self.tournaments = tournaments.tournaments
    }
    task.resume()
}


比赛结构:

struct Tournament : Codable {
    let id: Int
    let name: String
    let game_id: Int
    let game_iteration_id: Int
    let state: Int
    let starts_at: String
    let creator_id: Int
    let stream_url: String
    let entrant_count: Int
    let prereg_count: Int
    let path: String
}

struct TournamentPage : Codable {
    let page: Int?
    let results_per_page: String
    let tournament_count: Int
    let tournaments: [Tournament]
}

1 个答案:

答案 0 :(得分:1)

您在guard语句中有误。您在==中写了!=而不是json.count == 0。它应该类似于下面的代码:

guard json.count != 0 else {
    print("Zero bytes of data")
    return
}

在操场上使用以下代码(已删除编码器)进行了测试:

let baseURL: String = "https://www.burningmeter.com/tournaments.json?page=1"


func retrieveAPIData() {
    var request: URLRequest = URLRequest(url: URL(string: baseURL)!)
    request.cachePolicy = URLRequest.CachePolicy.reloadIgnoringLocalCacheData
    request.addValue("application/json; charset=utf-8", forHTTPHeaderField: "Content-Type")
    request.httpMethod = "GET"

    // Request the data
    let session: URLSession = URLSession.shared
    let task = session.dataTask(with: request) { (data, response, error) in
        print(data!.count)
        print(response)
        // Did we get an error?
        guard error == nil else {
            print(error!)
            return
        }

        guard let json = data else {
            print("No data")
            return
        }

        guard json.count != 0 else {
            print("Zero bytes of data")
            return
        }
        print(String(decoding: json, as: UTF8.self))
    }
    task.resume()
}

retrieveAPIData()

打印结果:

8031
Optional(<NSHTTPURLResponse: 0x7fbce1650fc0> { URL: https://www.burningmeter.com/tournaments.json?page=1 } { Status Code: 200, Headers {
    "Access-Control-Allow-Origin" =     (
        "*"
    );
    "Cache-Control" =     (
        "max-age=0, private, must-revalidate"
    );
    Connection =     (
        "keep-alive"
    );
    "Content-Type" =     (
        "application/json; charset=utf-8"
    );
    Date =     (
        "Thu, 08 Nov 2018 15:40:40 GMT"
    );
    Etag =     (
        "W/\"5d5a17c8ff6f705d6bb56c6ed8b6a099\""
    );
    Server =     (
        Cowboy
    );
    "Strict-Transport-Security" =     (
        "max-age=31536000"
    );
    "Transfer-Encoding" =     (
        Identity
    );
    Via =     (
        "1.1 vegur"
    );
    "X-Content-Type-Options" =     (
        nosniff
    );
    "X-Frame-Options" =     (
        SAMEORIGIN
    );
    "X-Request-Id" =     (
        "0d7f8ae9-92d2-41d8-8678-6c9b2bdb5e3b"
    );
    "X-Runtime" =     (
        "0.044064"
    );
    "X-Xss-Protection" =     (
        "1; mode=block"
    );
} })


JSON结果:

{
    "page": "1",
    "results_per_page": "50",
    "tournament_count": 33,
    "tournaments": [{
            "id": 1872,
            "name": "Pinup Biweekly - Nov 1",
            "game_id": 90,
            "game_iteration_id": 133,
            "state": 30,
            "starts_at": "2018-11-02T00:00:00.000Z",
            "creator_id": 960,
            "stream_url": null,
            "entrant_count": 6,
            "prereg_count": 0,
            "path": "/t/1872/pinup-biweekly-nov-1"
        }, {
            "id": 1874,
            "name": "IBTY #45",
            "game_id": 21,
            "game_iteration_id": 38,
            "state": 30,
            "starts_at": "2018-11-02T22:03:00.000Z",
            "creator_id": 185,
            "stream_url": null,
            "entrant_count": 11,
            "prereg_count": 0,
            "path": "/t/1874/ibty-45"
        }, {
            "id": 1875,
            "name": "SFV Weekly 11/2/18",
            "game_id": 6,
            "game_iteration_id": 14,
            "state": 30,
            "starts_at": "2018-11-03T00:55:00.000Z",
            "creator_id": 957,
            "stream_url": null,
            "entrant_count": 9,
            "prereg_count": 0,
            "path": "/t/1875/sfv-weekly-11-2-18"
        }, {
            "id": 1876,
            "name": "Weekly SC6 11/2/18",
            "game_id": 106,
            "game_iteration_id": 149,
            "state": 20,
            "starts_at": "2018-11-03T01:04:00.000Z",
            "creator_id": 957,
            "stream_url": null,
            "entrant_count": 6,
            "prereg_count": 0,
            "path": "/t/1876/weekly-sc6-11-2-18"
        }, {
            "id": 1879,
            "name": "UNIST - WS 11/3",
            "game_id": 12,
            "game_iteration_id": 23,
            "state": 30,
            "starts_at": "2018-11-03T18:30:00.000Z",
            "creator_id": 949,
            "stream_url": null,
            "entrant_count": 8,
            "prereg_count": 0,
            "path": "/t/1879/unist-ws-11-3"
        }, {
            "id": 1881,
            "name": "DBFZ - WS 11/3",
            "game_id": 86,
            "game_iteration_id": 129,
            "state": 30,
            "starts_at": "2018-11-03T18:30:00.000Z",
            "creator_id": 949,
            "stream_url": null,
            "entrant_count": 8,
            "prereg_count": 0,
            "path": "/t/1881/dbfz-ws-11-3"
        }, {
            "id": 1882,
            "name": "SFV - WS 11/3",
            "game_id": 6,
            "game_iteration_id": 14,
            // more
        }
        // More output here
}

接收到的长度为8031