質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.53%

  • Swift

    8559questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    4814questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • iOS

    4574questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • iPhone

    1095questions

    iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

SwiftでAPIを使ってJSONの生データを取得する

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,428

Kochan

score 37

前提・実現したいこと

住所検索のAPIを使い、JSONデータを取得したいと考えています。
データが取得できたかどうかをprintを使って確かめようとしました。

ATSの設定でHTTPの許可はできたのですが、
コードが間違っているのかJSONデータの取得ができません。

非常に長いエラーメッセージの下半分ほどを載せておきます。
お手数おかけしますが、よろしくお願いします。

発生している問題・エラーメッセージ

2016-10-11 21:46:44.778680 zipAddress2[46454:16559674] [] nw_resolver_start_query_timer Starting 1s query timer to receive all address families for api.zipaddress.net:80
2016-10-11 21:46:44.779090 zipAddress2[46454:16559674] [] nw_endpoint_resolver_update [1 api.zipaddress.net:80 in_progress resolver (satisfied)] resolver is in_progress
2016-10-11 21:46:44.779426 zipAddress2[46454:16559674] [] nw_endpoint_resolver_update [1 api.zipaddress.net:80 in_progress resolver (satisfied)] Updated endpoint list is ()
2016-10-11 21:46:44.883036 zipAddress2[46454:16559674] [] nw_resolver_host_resolve_callback flags=0x2 ifindex=0 error=NoError(0) hostname=api.zipaddress.net. addr=49.212.197.242:0 ttl=1500
2016-10-11 21:46:44.886266 zipAddress2[46454:16559674] [] nw_resolver_cancel_query_timer Cancelling query timer for api.zipaddress.net
2016-10-11 21:46:44.887054 zipAddress2[46454:16559673] [] nw_endpoint_resolver_update [1 api.zipaddress.net:80 in_progress resolver (satisfied)] resolver is complete
2016-10-11 21:46:44.887629 zipAddress2[46454:16559673] [] nw_endpoint_resolver_update [1 api.zipaddress.net:80 in_progress resolver (satisfied)] Adding endpoint handler for 49.212.197.242:80
2016-10-11 21:46:44.888107 zipAddress2[46454:16559673] [] nw_endpoint_resolver_update [1 api.zipaddress.net:80 in_progress resolver (satisfied)] Updated endpoint list is (49.212.197.242:80)
2016-10-11 21:46:44.888654 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1 api.zipaddress.net:80 in_progress resolver (satisfied)] reported event resolver:receive_dns
2016-10-11 21:46:44.889148 zipAddress2[46454:16559673] [] nw_endpoint_resolver_start_next_child [1 api.zipaddress.net:80 in_progress resolver (satisfied)] starting child endpoint 49.212.197.242:80
2016-10-11 21:46:44.889810 zipAddress2[46454:16559673] [] nw_endpoint_resolver_start_next_child [1 api.zipaddress.net:80 in_progress resolver (satisfied)] starting next child endpoint in 100ms
2016-10-11 21:46:44.890443 zipAddress2[46454:16559673] [] nw_endpoint_handler_start [1.1 49.212.197.242:80 initial path (null)]
2016-10-11 21:46:44.890969 zipAddress2[46454:16559673] [] nw_endpoint_resolver_receive_report [1 api.zipaddress.net:80 in_progress resolver (satisfied)] received child report:[1.1 49.212.197.242:80 initial path (null)]
2016-10-11 21:46:44.891478 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1.1 49.212.197.242:80 initial path (null)] reported event path:start
2016-10-11 21:46:44.892400 zipAddress2[46454:16559673] [] nw_endpoint_handler_path_change [1.1 49.212.197.242:80 waiting path (satisfied)]
2016-10-11 21:46:44.892877 zipAddress2[46454:16559673] [] nw_endpoint_resolver_receive_report [1 api.zipaddress.net:80 in_progress resolver (satisfied)] received child report:[1.1 49.212.197.242:80 waiting path (satisfied)]
2016-10-11 21:46:44.893412 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1.1 49.212.197.242:80 waiting path (satisfied)] reported event path:satisfied
2016-10-11 21:46:44.894088 zipAddress2[46454:16559673] [] nw_endpoint_proxy_handler_should_use_proxy Looking up proxy for hostname: <nil>, ifindex: 0
2016-10-11 21:46:44.895717 zipAddress2[46454:16559673] [] -[NWConcrete_nw_endpoint_flow startWithHandler:] [1.1 49.212.197.242:80 waiting socket-flow (satisfied)]
2016-10-11 21:46:44.896217 zipAddress2[46454:16559673] [] nw_endpoint_flow_setup_socket [1.1 49.212.197.242:80 in_progress socket-flow (satisfied)] creating socket
2016-10-11 21:46:44.896842 zipAddress2[46454:16559673] [] nw_endpoint_flow_attach_protocols [1.1 49.212.197.242:80 in_progress socket-flow (satisfied)]
2016-10-11 21:46:44.897827 zipAddress2[46454:16559673] [] nw_endpoint_flow_attach_protocols [1.1 49.212.197.242:80 in_progress socket-flow (satisfied)] Attached flow protocol
2016-10-11 21:46:44.898391 zipAddress2[46454:16559673] [] nw_endpoint_resolver_receive_report [1 api.zipaddress.net:80 in_progress resolver (satisfied)] received child report:[1.1 49.212.197.242:80 in_progress socket-flow (satisfied)]
2016-10-11 21:46:44.899064 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1.1 49.212.197.242:80 in_progress socket-flow (satisfied)] reported event flow:start_connect
2016-10-11 21:46:44.917982 zipAddress2[46454:16559673] [] nw_socket_handle_socket_event Event mask: 0x800
2016-10-11 21:46:44.918833 zipAddress2[46454:16559673] [] nw_socket_handle_socket_event Socket received CONNECTED event
2016-10-11 21:46:44.919645 zipAddress2[46454:16559673] [] nw_socket_setup_notsent_lowat Set TCP_NOTSENT_LOWAT(16384)
2016-10-11 21:46:44.920208 zipAddress2[46454:16559673] [] nw_endpoint_flow_protocol_connected [1.1 49.212.197.242:80 in_progress socket-flow (satisfied)] Output protocol connected
2016-10-11 21:46:44.921557 zipAddress2[46454:16559673] [] nw_endpoint_flow_connected_path_change [1.1 49.212.197.242:80 ready socket-flow (satisfied)]
2016-10-11 21:46:44.922026 zipAddress2[46454:16559673] [] nw_endpoint_flow_connected_path_change [1.1 49.212.197.242:80 ready socket-flow (satisfied)] Connected path is satisfied
2016-10-11 21:46:44.922412 zipAddress2[46454:16559673] [] nw_endpoint_resolver_receive_report [1 api.zipaddress.net:80 in_progress resolver (satisfied)] received child report:[1.1 49.212.197.242:80 ready socket-flow (satisfied)]
2016-10-11 21:46:44.922877 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1.1 49.212.197.242:80 ready socket-flow (satisfied)] reported event flow:finish_connect
2016-10-11 21:46:44.923510 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1 api.zipaddress.net:80 ready resolver (satisfied)] reported event flow:finish_connect
2016-10-11 21:46:44.924052 zipAddress2[46454:16559673] [] nw_endpoint_resolver_receive_report [1 api.zipaddress.net:80 ready resolver (satisfied)] received child report:[1.1 49.212.197.242:80 ready socket-flow (satisfied)]
2016-10-11 21:46:44.924523 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1.1 49.212.197.242:80 ready socket-flow (satisfied)] reported event flow:changed_viability
2016-10-11 21:46:44.925292 zipAddress2[46454:16559673] [] nw_connection_endpoint_report [1 api.zipaddress.net:80 ready resolver (satisfied)] reported event flow:changed_viability
2016-10-11 21:46:44.925920 zipAddress2[46454:16559674] [] __tcp_connection_start_block_invoke 1 sending event TCP_CONNECTION_EVENT_CONNECTED in response to state ready and error (null)
2016-10-11 21:46:44.926582 zipAddress2[46454:16559674] [] tcp_connection_event_notify 1 event: TCP_CONNECTION_EVENT_CONNECTED, reason: nw_connection event, should deliver: true
2016-10-11 21:46:44.927311 zipAddress2[46454:16559674] [] tcp_connection_get_statistics DNS: 112ms/117ms since start, TCP: 24ms/151ms since start, TLS: 0ms/0ms since start

該当のソースコード

import UIKit

class ViewController: UIViewController {
    @IBOutlet weak var zipTextField: UITextField!

    @IBAction func tapReturn() {
    }


    @IBAction func tapSearch() {
        guard let ziptext = zipTextField.text else{
            return
        }

        let urlStr = "http://api.zipaddress.net/?zipcode=\(ziptext)"
        print(urlStr)

        if let url = URL(string: urlStr){
            let urlSession = URLSession.shared
            let task = urlSession.dataTask(with: url, completionHandler: self.onGetAddress)
            task.resume()

        }

    }
    func onGetAddress(data: Data?,res : URLResponse?, error: Error?){
       print(data)
    }


    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


}

試したこと

print(data)をコメントで無効化してみましたが、
結果は変わらなかったので
dataの中身を取得できていないのかなと思います。

エラーメッセージの一部を検索してみたのですが、
解決に繋がるような情報が見つけられませんでした。

補足情報(言語/FW/ツール等のバージョンなど)

fuzzballさんへの返答です。
ATSの設定は以下の画像のようになっています。
イメージ説明

googleにすると、ビルドは成功し、住所検索を実行しようとするとlldbのエラーがコンソールに出ました。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • fuzzball

    2016/10/12 17:51 編集

    ATSの設定は、具体的にどういうことをしたのでしょうか?urlStrを https://www.google.co.jp/ にするとどうなるでしょうか?

    キャンセル

  • fuzzball

    2016/10/14 10:34 編集

    "lldb"というのはプロンプトであってエラーメッセージではありません。その上の行までに表示されているログを書いて下さい。

    キャンセル

回答 1

checkベストアンサー

+3

一連の[] nw_*というログはエラーではありません。Xcode 8から大量に出るようになったネットワークのログです。エラーではないので気にする必要がありません。

書かれているコードは動くはずなので、ログに紛れてprint()で出力しているところを見つけられないのかもしれません。また、dataをそのままprint()で出力しても出力されるのはOptional(207 bytes)というような値だと思います。

JSONを出力したいということですのでdataを文字列に変換して出力するのがいいと思います。onGetAddress()メソッドを下記のように変えてみてください。JSONが出力されるかdatanullならクラッシュするかのどちらかになります。

もし、よくわからなければ、どこまで処理が進んでいるかブレークポイントなどを使ってデバッグするといいです。

func onGetAddress(data: Data?,res : URLResponse?, error: Error?) {
    print(String(data: data!, encoding: .utf8))
}

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/12 15:22

    これらはエラーではなかったのですね!

    いただいたコードで実行してみたところ、ビルドまではうまくいき、
    JSONデータを取得するところでプログラムが止まってしまいました。

    いただいたコードの部分に
    Thread 3 : breakpoint1.1 2.1 と、
    コンソールにはlldbと出たのですが、
    これはJSONデータを取得できていなく、クラッシュしているという認識で正しいのでしょうか?

    キャンセル

  • 2016/10/12 15:42

    自分でブレークポイントを置いたりしてないならおそらくそうでしょうね。URLには有効な値が入ってるんですか?`print(urlStr)`の結果は何と出てますか?

    キャンセル

  • 2016/10/12 16:41

    そこは確認しながら進めていました。

    画面で1000000をzipTextとして入力すると
    http://api.zipaddress.net/?zipcode=1000000
    このようになっています。

    キャンセル

  • 2016/10/12 17:21

    APIをChromeで直接打つと、このような文字列が得られましたので
    APIは有効だと思います。

    {"code":200,"data":{"pref":"\u6771\u4eac\u90fd","address":"\u5343\u4ee3\u7530\u533a","city":"\u5343\u4ee3\u7530\u533a","town":"","fullAddress":"\u6771\u4eac\u90fd\u5343\u4ee3\u7530\u533a"}}

    キャンセル

  • 2016/10/12 17:27

    失敗する要素はなさそうですけどね。JSONの出力の前に`print(res)`と、`print(error)`を書いて内容を確かめてみてください。

    キャンセル

  • 2016/10/13 23:16

    print(res)のところでブレークポイントが入ってしまいました。

    キャンセル

  • 2016/10/14 10:31

    print(error)の出力は?

    キャンセル

  • 2016/10/14 14:29

    shift+command+Kでクリーンアップしてからビルドしたところ、
    うまく下記のJSONデータを取得できました!

    Optional(<NSHTTPURLResponse: 0x6000004242a0> { URL: http://api.zipaddress.net/?zipcode=1000000 } { status code: 200, headers {
    "Accept-Ranges" = bytes;
    "Access-Control-Allow-Origin" = "*";
    Age = 0;
    Connection = "keep-alive";
    "Content-Length" = 189;
    "Content-Type" = "application/json; charset=UTF-8";
    Date = "Fri, 14 Oct 2016 05:27:18 GMT";
    Server = "nginx/1.1.19";
    Via = "1.1 varnish";
    "X-Varnish" = 927821262;
    } })
    nil
    Optional("{\"code\":200,\"data\":{\"pref\":\"\\u6771\\u4eac\\u90fd\",\"address\":\"\\u5343\\u4ee3\\u7530\\u533a\",\"city\":\"\\u5343\\u4ee3\\u7530\\u533a\",\"town\":\"\",\"fullAddress\":\"\\u6771\\u4eac\\u90fd\\u5343\\u4ee3\\u7530\\u533a\"}}")

    k_katsumi様、fuzzball様、
    ご教授ありがとうございました!!

    キャンセル

同じタグがついた質問を見る

  • Swift

    8559questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    4814questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • iOS

    4574questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • iPhone

    1095questions

    iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。