How to get JSON response in Golang





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}







93















I'm trying read JSON data from web, but that code returns empty result. I'm not sure what I'm doing wrong here.



package main

import "os"
import "fmt"
import "net/http"
import "io/ioutil"
import "encoding/json"

type Tracks struct {
Toptracks Toptracks_info
}

type Toptracks_info struct {
Track Track_info
Attr Attr_info
}

type Track_info struct {
Name string
Duration string
Listeners string
Mbid string
Url string
Streamable Streamable_info
Artist Artist_info
Attr Track_attr_info
}

type Attr_info struct {
Country string
Page string
PerPage string
TotalPages string
Total string
}

type Streamable_info struct {
Text string
Fulltrack string
}

type Artist_info struct {
Name string
Mbid string
Url string
}

type Track_attr_info struct {
Rank string
}

func get_content() {
// json data
url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

res, err := http.Get(url)

if err != nil {
panic(err.Error())
}

body, err := ioutil.ReadAll(res.Body)

if err != nil {
panic(err.Error())
}

var data Tracks
json.Unmarshal(body, &data)
fmt.Printf("Results: %vn", data)
os.Exit(0)
}

func main() {
get_content()
}









share|improve this question































    93















    I'm trying read JSON data from web, but that code returns empty result. I'm not sure what I'm doing wrong here.



    package main

    import "os"
    import "fmt"
    import "net/http"
    import "io/ioutil"
    import "encoding/json"

    type Tracks struct {
    Toptracks Toptracks_info
    }

    type Toptracks_info struct {
    Track Track_info
    Attr Attr_info
    }

    type Track_info struct {
    Name string
    Duration string
    Listeners string
    Mbid string
    Url string
    Streamable Streamable_info
    Artist Artist_info
    Attr Track_attr_info
    }

    type Attr_info struct {
    Country string
    Page string
    PerPage string
    TotalPages string
    Total string
    }

    type Streamable_info struct {
    Text string
    Fulltrack string
    }

    type Artist_info struct {
    Name string
    Mbid string
    Url string
    }

    type Track_attr_info struct {
    Rank string
    }

    func get_content() {
    // json data
    url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

    res, err := http.Get(url)

    if err != nil {
    panic(err.Error())
    }

    body, err := ioutil.ReadAll(res.Body)

    if err != nil {
    panic(err.Error())
    }

    var data Tracks
    json.Unmarshal(body, &data)
    fmt.Printf("Results: %vn", data)
    os.Exit(0)
    }

    func main() {
    get_content()
    }









    share|improve this question



























      93












      93








      93


      45






      I'm trying read JSON data from web, but that code returns empty result. I'm not sure what I'm doing wrong here.



      package main

      import "os"
      import "fmt"
      import "net/http"
      import "io/ioutil"
      import "encoding/json"

      type Tracks struct {
      Toptracks Toptracks_info
      }

      type Toptracks_info struct {
      Track Track_info
      Attr Attr_info
      }

      type Track_info struct {
      Name string
      Duration string
      Listeners string
      Mbid string
      Url string
      Streamable Streamable_info
      Artist Artist_info
      Attr Track_attr_info
      }

      type Attr_info struct {
      Country string
      Page string
      PerPage string
      TotalPages string
      Total string
      }

      type Streamable_info struct {
      Text string
      Fulltrack string
      }

      type Artist_info struct {
      Name string
      Mbid string
      Url string
      }

      type Track_attr_info struct {
      Rank string
      }

      func get_content() {
      // json data
      url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

      res, err := http.Get(url)

      if err != nil {
      panic(err.Error())
      }

      body, err := ioutil.ReadAll(res.Body)

      if err != nil {
      panic(err.Error())
      }

      var data Tracks
      json.Unmarshal(body, &data)
      fmt.Printf("Results: %vn", data)
      os.Exit(0)
      }

      func main() {
      get_content()
      }









      share|improve this question
















      I'm trying read JSON data from web, but that code returns empty result. I'm not sure what I'm doing wrong here.



      package main

      import "os"
      import "fmt"
      import "net/http"
      import "io/ioutil"
      import "encoding/json"

      type Tracks struct {
      Toptracks Toptracks_info
      }

      type Toptracks_info struct {
      Track Track_info
      Attr Attr_info
      }

      type Track_info struct {
      Name string
      Duration string
      Listeners string
      Mbid string
      Url string
      Streamable Streamable_info
      Artist Artist_info
      Attr Track_attr_info
      }

      type Attr_info struct {
      Country string
      Page string
      PerPage string
      TotalPages string
      Total string
      }

      type Streamable_info struct {
      Text string
      Fulltrack string
      }

      type Artist_info struct {
      Name string
      Mbid string
      Url string
      }

      type Track_attr_info struct {
      Rank string
      }

      func get_content() {
      // json data
      url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

      res, err := http.Get(url)

      if err != nil {
      panic(err.Error())
      }

      body, err := ioutil.ReadAll(res.Body)

      if err != nil {
      panic(err.Error())
      }

      var data Tracks
      json.Unmarshal(body, &data)
      fmt.Printf("Results: %vn", data)
      os.Exit(0)
      }

      func main() {
      get_content()
      }






      json go






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Aug 2 '16 at 19:41







      user6169399

















      asked Jun 17 '13 at 20:35









      AkshayAkshay

      98631629




      98631629
























          4 Answers
          4






          active

          oldest

          votes


















          198














          The ideal way is not to use ioutil.ReadAll, but rather use a decoder on the reader directly. Here's a nice function that gets a url and decodes its response onto a target structure.



          var myClient = &http.Client{Timeout: 10 * time.Second}

          func getJson(url string, target interface{}) error {
          r, err := myClient.Get(url)
          if err != nil {
          return err
          }
          defer r.Body.Close()

          return json.NewDecoder(r.Body).Decode(target)
          }


          Example use:



          type Foo struct {
          Bar string
          }

          func main() {
          foo1 := new(Foo) // or &Foo{}
          getJson("http://example.com", foo1)
          println(foo1.Bar)

          // alternately:

          foo2 := Foo{}
          getJson("http://example.com", &foo2)
          println(foo2.Bar)
          }


          You should not be using the default *http.Client structure in production as this answer originally demonstrated! (Which is what http.Get/etc call to). The reason is that the default client has no timeout set; if the remote server is unresponsive, you're going to have a bad day.






          share|improve this answer





















          • 4





            It seems like you need to use Uppercase for the names of the items in the struct e.g. type WebKeys struct { Keys struct { X5t string X5c string } } even when the actual params in the JSON you're parsing are in lower case. JSON example: { "keys": [{ "x5t": "foo", "x5c": "baaaar" }] }

            – Wilson
            May 9 '16 at 3:26






          • 1





            @Roman, no. If an error is returned, the response value is nil. (An error means we couldn't read any valid HTTP response, there's no body to close!) You can test this by pointing .Get() at a non-existent URL. Tis method is demonstrated in the second code block in the net/http docs.

            – Connor Peet
            Aug 6 '17 at 15:29








          • 1





            @NamGVU saves a potential allocation and allows the use of http keep-alive to reuse connections.

            – Connor Peet
            Nov 27 '17 at 22:16






          • 2





            @ConnorPeet You made my day thanks ! I wonder what you meant with "You should not be using the default *http.Client structure in production". Did you mean that one should use &http.Client{Timeout: 10 * time.Second} or use a whole other library/strategy ?

            – Jona Rodrigues
            Jan 18 '18 at 20:05






          • 2





            Just a warning to others - json.NewDecoder(r.Body).Decode(target) will not return an error for certain types of malformed JSON! I just wasted a few hours trying to understand why I kept getting an empty response - turns out the source JSON had an extra comma where it shouldn't have been. I suggest you use json.Unmarshal instead. There's also a good writeup about other potential dangers of using json.Decoder here

            – adamc
            Oct 6 '18 at 10:33



















          21














          Your Problem were the slice declarations in your data structs (except for Track, they shouldn't be slices...). This was compounded by some rather goofy fieldnames in the fetched json file, which can be fixed via structtags, see godoc.



          The code below parsed the json successfully. If you've further questions, let me know.



          package main

          import "fmt"
          import "net/http"
          import "io/ioutil"
          import "encoding/json"

          type Tracks struct {
          Toptracks Toptracks_info
          }

          type Toptracks_info struct {
          Track Track_info
          Attr Attr_info `json: "@attr"`
          }

          type Track_info struct {
          Name string
          Duration string
          Listeners string
          Mbid string
          Url string
          Streamable Streamable_info
          Artist Artist_info
          Attr Track_attr_info `json: "@attr"`
          }

          type Attr_info struct {
          Country string
          Page string
          PerPage string
          TotalPages string
          Total string
          }

          type Streamable_info struct {
          Text string `json: "#text"`
          Fulltrack string
          }

          type Artist_info struct {
          Name string
          Mbid string
          Url string
          }

          type Track_attr_info struct {
          Rank string
          }

          func perror(err error) {
          if err != nil {
          panic(err)
          }
          }

          func get_content() {
          url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

          res, err := http.Get(url)
          perror(err)
          defer res.Body.Close()

          decoder := json.NewDecoder(res.Body)
          var data Tracks
          err = decoder.Decode(&data)
          if err != nil {
          fmt.Printf("%Tn%sn%#vn",err, err, err)
          switch v := err.(type){
          case *json.SyntaxError:
          fmt.Println(string(body[v.Offset-40:v.Offset]))
          }
          }
          for i, track := range data.Toptracks.Track{
          fmt.Printf("%d: %s %sn", i, track.Artist.Name, track.Name)
          }
          }

          func main() {
          get_content()
          }





          share|improve this answer





















          • 1





            There is something in the response body.

            – peterSO
            Jun 17 '13 at 23:28






          • 4





            In my case, I was missing UPPER-CASE first character in the "struct" fields.

            – abourget
            Jun 8 '14 at 19:30











          • Answer below is right, using a Decoder directly on the response.Body avoids unnecessary allocations and is generally more ideomatic. Corrected my answer, thanks for pointing it out.

            – tike
            Dec 12 '15 at 18:30











          • @abourget omg thank you for this comment. Just spend 1 hours looking for problems in parser, confirming with wireshark that response is correct... thanks

            – agilob
            Mar 26 '17 at 20:15



















          12














          You need upper case property names in your structs in order to be used by the json packages.



          Upper case property names are exported properties. Lower case property names are not exported.



          You also need to pass the your data object by reference (&data).



          package main

          import "os"
          import "fmt"
          import "net/http"
          import "io/ioutil"
          import "encoding/json"

          type tracks struct {
          Toptracks toptracks_info
          }

          type toptracks_info struct {
          Track track_info
          Attr attr_info
          }

          type track_info struct {
          Name string
          Duration string
          Listeners string
          Mbid string
          Url string
          Streamable streamable_info
          Artist artist_info
          Attr track_attr_info
          }

          type attr_info struct {
          Country string
          Page string
          PerPage string
          TotalPages string
          Total string
          }

          type streamable_info struct {
          Text string
          Fulltrack string
          }

          type artist_info struct {
          Name string
          Mbid string
          Url string
          }

          type track_attr_info struct {
          Rank string
          }

          func get_content() {
          // json data
          url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

          res, err := http.Get(url)

          if err != nil {
          panic(err.Error())
          }

          body, err := ioutil.ReadAll(res.Body)

          if err != nil {
          panic(err.Error())
          }

          var data tracks
          json.Unmarshal(body, &data)
          fmt.Printf("Results: %vn", data)
          os.Exit(0)
          }

          func main() {
          get_content()
          }





          share|improve this answer


























          • still not work, is this working for you ? same empty response

            – Akshay
            Jun 17 '13 at 20:47








          • 2





            thanks for "You need upper case property names in your structs in order to be used by the json packages."

            – HVNSweeting
            Apr 28 '15 at 10:06



















          6














          The results from json.Unmarshal (into var data interface{}) do not directly match your Go type and variable declarations. For example,



          package main

          import (
          "encoding/json"
          "fmt"
          "io/ioutil"
          "net/http"
          "os"
          )

          type Tracks struct {
          Toptracks Toptracks_info
          }

          type Toptracks_info struct {
          Track Track_info
          Attr Attr_info
          }

          type Track_info struct {
          Name string
          Duration string
          Listeners string
          Mbid string
          Url string
          Streamable Streamable_info
          Artist Artist_info
          Attr Track_attr_info
          }

          type Attr_info struct {
          Country string
          Page string
          PerPage string
          TotalPages string
          Total string
          }

          type Streamable_info struct {
          Text string
          Fulltrack string
          }

          type Artist_info struct {
          Name string
          Mbid string
          Url string
          }

          type Track_attr_info struct {
          Rank string
          }

          func get_content() {
          // json data
          url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"
          url += "&limit=1" // limit data for testing
          res, err := http.Get(url)
          if err != nil {
          panic(err.Error())
          }
          body, err := ioutil.ReadAll(res.Body)
          if err != nil {
          panic(err.Error())
          }
          var data interface{} // TopTracks
          err = json.Unmarshal(body, &data)
          if err != nil {
          panic(err.Error())
          }
          fmt.Printf("Results: %vn", data)
          os.Exit(0)
          }

          func main() {
          get_content()
          }


          Output:



          Results: map[toptracks:map[track:map[name:Get Lucky (feat. Pharrell Williams) listeners:1863 url:http://www.last.fm/music/Daft+Punk/_/Get+Lucky+(feat.+Pharrell+Williams) artist:map[name:Daft Punk mbid:056e4f3e-d505-4dad-8ec1-d04f521cbb56 url:http://www.last.fm/music/Daft+Punk] image:[map[#text:http://userserve-ak.last.fm/serve/34s/88137413.png size:small] map[#text:http://userserve-ak.last.fm/serve/64s/88137413.png size:medium] map[#text:http://userserve-ak.last.fm/serve/126/88137413.png size:large] map[#text:http://userserve-ak.last.fm/serve/300x300/88137413.png size:extralarge]] @attr:map[rank:1] duration:369 mbid: streamable:map[#text:1 fulltrack:0]] @attr:map[country:Netherlands page:1 perPage:1 totalPages:500 total:500]]]





          share|improve this answer
























            Your Answer






            StackExchange.ifUsing("editor", function () {
            StackExchange.using("externalEditor", function () {
            StackExchange.using("snippets", function () {
            StackExchange.snippets.init();
            });
            });
            }, "code-snippets");

            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "1"
            };
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function() {
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled) {
            StackExchange.using("snippets", function() {
            createEditor();
            });
            }
            else {
            createEditor();
            }
            });

            function createEditor() {
            StackExchange.prepareEditor({
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader: {
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            },
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            });


            }
            });














            draft saved

            draft discarded


















            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f17156371%2fhow-to-get-json-response-in-golang%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            4 Answers
            4






            active

            oldest

            votes








            4 Answers
            4






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            198














            The ideal way is not to use ioutil.ReadAll, but rather use a decoder on the reader directly. Here's a nice function that gets a url and decodes its response onto a target structure.



            var myClient = &http.Client{Timeout: 10 * time.Second}

            func getJson(url string, target interface{}) error {
            r, err := myClient.Get(url)
            if err != nil {
            return err
            }
            defer r.Body.Close()

            return json.NewDecoder(r.Body).Decode(target)
            }


            Example use:



            type Foo struct {
            Bar string
            }

            func main() {
            foo1 := new(Foo) // or &Foo{}
            getJson("http://example.com", foo1)
            println(foo1.Bar)

            // alternately:

            foo2 := Foo{}
            getJson("http://example.com", &foo2)
            println(foo2.Bar)
            }


            You should not be using the default *http.Client structure in production as this answer originally demonstrated! (Which is what http.Get/etc call to). The reason is that the default client has no timeout set; if the remote server is unresponsive, you're going to have a bad day.






            share|improve this answer





















            • 4





              It seems like you need to use Uppercase for the names of the items in the struct e.g. type WebKeys struct { Keys struct { X5t string X5c string } } even when the actual params in the JSON you're parsing are in lower case. JSON example: { "keys": [{ "x5t": "foo", "x5c": "baaaar" }] }

              – Wilson
              May 9 '16 at 3:26






            • 1





              @Roman, no. If an error is returned, the response value is nil. (An error means we couldn't read any valid HTTP response, there's no body to close!) You can test this by pointing .Get() at a non-existent URL. Tis method is demonstrated in the second code block in the net/http docs.

              – Connor Peet
              Aug 6 '17 at 15:29








            • 1





              @NamGVU saves a potential allocation and allows the use of http keep-alive to reuse connections.

              – Connor Peet
              Nov 27 '17 at 22:16






            • 2





              @ConnorPeet You made my day thanks ! I wonder what you meant with "You should not be using the default *http.Client structure in production". Did you mean that one should use &http.Client{Timeout: 10 * time.Second} or use a whole other library/strategy ?

              – Jona Rodrigues
              Jan 18 '18 at 20:05






            • 2





              Just a warning to others - json.NewDecoder(r.Body).Decode(target) will not return an error for certain types of malformed JSON! I just wasted a few hours trying to understand why I kept getting an empty response - turns out the source JSON had an extra comma where it shouldn't have been. I suggest you use json.Unmarshal instead. There's also a good writeup about other potential dangers of using json.Decoder here

              – adamc
              Oct 6 '18 at 10:33
















            198














            The ideal way is not to use ioutil.ReadAll, but rather use a decoder on the reader directly. Here's a nice function that gets a url and decodes its response onto a target structure.



            var myClient = &http.Client{Timeout: 10 * time.Second}

            func getJson(url string, target interface{}) error {
            r, err := myClient.Get(url)
            if err != nil {
            return err
            }
            defer r.Body.Close()

            return json.NewDecoder(r.Body).Decode(target)
            }


            Example use:



            type Foo struct {
            Bar string
            }

            func main() {
            foo1 := new(Foo) // or &Foo{}
            getJson("http://example.com", foo1)
            println(foo1.Bar)

            // alternately:

            foo2 := Foo{}
            getJson("http://example.com", &foo2)
            println(foo2.Bar)
            }


            You should not be using the default *http.Client structure in production as this answer originally demonstrated! (Which is what http.Get/etc call to). The reason is that the default client has no timeout set; if the remote server is unresponsive, you're going to have a bad day.






            share|improve this answer





















            • 4





              It seems like you need to use Uppercase for the names of the items in the struct e.g. type WebKeys struct { Keys struct { X5t string X5c string } } even when the actual params in the JSON you're parsing are in lower case. JSON example: { "keys": [{ "x5t": "foo", "x5c": "baaaar" }] }

              – Wilson
              May 9 '16 at 3:26






            • 1





              @Roman, no. If an error is returned, the response value is nil. (An error means we couldn't read any valid HTTP response, there's no body to close!) You can test this by pointing .Get() at a non-existent URL. Tis method is demonstrated in the second code block in the net/http docs.

              – Connor Peet
              Aug 6 '17 at 15:29








            • 1





              @NamGVU saves a potential allocation and allows the use of http keep-alive to reuse connections.

              – Connor Peet
              Nov 27 '17 at 22:16






            • 2





              @ConnorPeet You made my day thanks ! I wonder what you meant with "You should not be using the default *http.Client structure in production". Did you mean that one should use &http.Client{Timeout: 10 * time.Second} or use a whole other library/strategy ?

              – Jona Rodrigues
              Jan 18 '18 at 20:05






            • 2





              Just a warning to others - json.NewDecoder(r.Body).Decode(target) will not return an error for certain types of malformed JSON! I just wasted a few hours trying to understand why I kept getting an empty response - turns out the source JSON had an extra comma where it shouldn't have been. I suggest you use json.Unmarshal instead. There's also a good writeup about other potential dangers of using json.Decoder here

              – adamc
              Oct 6 '18 at 10:33














            198












            198








            198







            The ideal way is not to use ioutil.ReadAll, but rather use a decoder on the reader directly. Here's a nice function that gets a url and decodes its response onto a target structure.



            var myClient = &http.Client{Timeout: 10 * time.Second}

            func getJson(url string, target interface{}) error {
            r, err := myClient.Get(url)
            if err != nil {
            return err
            }
            defer r.Body.Close()

            return json.NewDecoder(r.Body).Decode(target)
            }


            Example use:



            type Foo struct {
            Bar string
            }

            func main() {
            foo1 := new(Foo) // or &Foo{}
            getJson("http://example.com", foo1)
            println(foo1.Bar)

            // alternately:

            foo2 := Foo{}
            getJson("http://example.com", &foo2)
            println(foo2.Bar)
            }


            You should not be using the default *http.Client structure in production as this answer originally demonstrated! (Which is what http.Get/etc call to). The reason is that the default client has no timeout set; if the remote server is unresponsive, you're going to have a bad day.






            share|improve this answer















            The ideal way is not to use ioutil.ReadAll, but rather use a decoder on the reader directly. Here's a nice function that gets a url and decodes its response onto a target structure.



            var myClient = &http.Client{Timeout: 10 * time.Second}

            func getJson(url string, target interface{}) error {
            r, err := myClient.Get(url)
            if err != nil {
            return err
            }
            defer r.Body.Close()

            return json.NewDecoder(r.Body).Decode(target)
            }


            Example use:



            type Foo struct {
            Bar string
            }

            func main() {
            foo1 := new(Foo) // or &Foo{}
            getJson("http://example.com", foo1)
            println(foo1.Bar)

            // alternately:

            foo2 := Foo{}
            getJson("http://example.com", &foo2)
            println(foo2.Bar)
            }


            You should not be using the default *http.Client structure in production as this answer originally demonstrated! (Which is what http.Get/etc call to). The reason is that the default client has no timeout set; if the remote server is unresponsive, you're going to have a bad day.







            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited Mar 23 '17 at 20:37









            random

            8,24075674




            8,24075674










            answered Jun 30 '15 at 5:06









            Connor PeetConnor Peet

            4,13831731




            4,13831731








            • 4





              It seems like you need to use Uppercase for the names of the items in the struct e.g. type WebKeys struct { Keys struct { X5t string X5c string } } even when the actual params in the JSON you're parsing are in lower case. JSON example: { "keys": [{ "x5t": "foo", "x5c": "baaaar" }] }

              – Wilson
              May 9 '16 at 3:26






            • 1





              @Roman, no. If an error is returned, the response value is nil. (An error means we couldn't read any valid HTTP response, there's no body to close!) You can test this by pointing .Get() at a non-existent URL. Tis method is demonstrated in the second code block in the net/http docs.

              – Connor Peet
              Aug 6 '17 at 15:29








            • 1





              @NamGVU saves a potential allocation and allows the use of http keep-alive to reuse connections.

              – Connor Peet
              Nov 27 '17 at 22:16






            • 2





              @ConnorPeet You made my day thanks ! I wonder what you meant with "You should not be using the default *http.Client structure in production". Did you mean that one should use &http.Client{Timeout: 10 * time.Second} or use a whole other library/strategy ?

              – Jona Rodrigues
              Jan 18 '18 at 20:05






            • 2





              Just a warning to others - json.NewDecoder(r.Body).Decode(target) will not return an error for certain types of malformed JSON! I just wasted a few hours trying to understand why I kept getting an empty response - turns out the source JSON had an extra comma where it shouldn't have been. I suggest you use json.Unmarshal instead. There's also a good writeup about other potential dangers of using json.Decoder here

              – adamc
              Oct 6 '18 at 10:33














            • 4





              It seems like you need to use Uppercase for the names of the items in the struct e.g. type WebKeys struct { Keys struct { X5t string X5c string } } even when the actual params in the JSON you're parsing are in lower case. JSON example: { "keys": [{ "x5t": "foo", "x5c": "baaaar" }] }

              – Wilson
              May 9 '16 at 3:26






            • 1





              @Roman, no. If an error is returned, the response value is nil. (An error means we couldn't read any valid HTTP response, there's no body to close!) You can test this by pointing .Get() at a non-existent URL. Tis method is demonstrated in the second code block in the net/http docs.

              – Connor Peet
              Aug 6 '17 at 15:29








            • 1





              @NamGVU saves a potential allocation and allows the use of http keep-alive to reuse connections.

              – Connor Peet
              Nov 27 '17 at 22:16






            • 2





              @ConnorPeet You made my day thanks ! I wonder what you meant with "You should not be using the default *http.Client structure in production". Did you mean that one should use &http.Client{Timeout: 10 * time.Second} or use a whole other library/strategy ?

              – Jona Rodrigues
              Jan 18 '18 at 20:05






            • 2





              Just a warning to others - json.NewDecoder(r.Body).Decode(target) will not return an error for certain types of malformed JSON! I just wasted a few hours trying to understand why I kept getting an empty response - turns out the source JSON had an extra comma where it shouldn't have been. I suggest you use json.Unmarshal instead. There's also a good writeup about other potential dangers of using json.Decoder here

              – adamc
              Oct 6 '18 at 10:33








            4




            4





            It seems like you need to use Uppercase for the names of the items in the struct e.g. type WebKeys struct { Keys struct { X5t string X5c string } } even when the actual params in the JSON you're parsing are in lower case. JSON example: { "keys": [{ "x5t": "foo", "x5c": "baaaar" }] }

            – Wilson
            May 9 '16 at 3:26





            It seems like you need to use Uppercase for the names of the items in the struct e.g. type WebKeys struct { Keys struct { X5t string X5c string } } even when the actual params in the JSON you're parsing are in lower case. JSON example: { "keys": [{ "x5t": "foo", "x5c": "baaaar" }] }

            – Wilson
            May 9 '16 at 3:26




            1




            1





            @Roman, no. If an error is returned, the response value is nil. (An error means we couldn't read any valid HTTP response, there's no body to close!) You can test this by pointing .Get() at a non-existent URL. Tis method is demonstrated in the second code block in the net/http docs.

            – Connor Peet
            Aug 6 '17 at 15:29







            @Roman, no. If an error is returned, the response value is nil. (An error means we couldn't read any valid HTTP response, there's no body to close!) You can test this by pointing .Get() at a non-existent URL. Tis method is demonstrated in the second code block in the net/http docs.

            – Connor Peet
            Aug 6 '17 at 15:29






            1




            1





            @NamGVU saves a potential allocation and allows the use of http keep-alive to reuse connections.

            – Connor Peet
            Nov 27 '17 at 22:16





            @NamGVU saves a potential allocation and allows the use of http keep-alive to reuse connections.

            – Connor Peet
            Nov 27 '17 at 22:16




            2




            2





            @ConnorPeet You made my day thanks ! I wonder what you meant with "You should not be using the default *http.Client structure in production". Did you mean that one should use &http.Client{Timeout: 10 * time.Second} or use a whole other library/strategy ?

            – Jona Rodrigues
            Jan 18 '18 at 20:05





            @ConnorPeet You made my day thanks ! I wonder what you meant with "You should not be using the default *http.Client structure in production". Did you mean that one should use &http.Client{Timeout: 10 * time.Second} or use a whole other library/strategy ?

            – Jona Rodrigues
            Jan 18 '18 at 20:05




            2




            2





            Just a warning to others - json.NewDecoder(r.Body).Decode(target) will not return an error for certain types of malformed JSON! I just wasted a few hours trying to understand why I kept getting an empty response - turns out the source JSON had an extra comma where it shouldn't have been. I suggest you use json.Unmarshal instead. There's also a good writeup about other potential dangers of using json.Decoder here

            – adamc
            Oct 6 '18 at 10:33





            Just a warning to others - json.NewDecoder(r.Body).Decode(target) will not return an error for certain types of malformed JSON! I just wasted a few hours trying to understand why I kept getting an empty response - turns out the source JSON had an extra comma where it shouldn't have been. I suggest you use json.Unmarshal instead. There's also a good writeup about other potential dangers of using json.Decoder here

            – adamc
            Oct 6 '18 at 10:33













            21














            Your Problem were the slice declarations in your data structs (except for Track, they shouldn't be slices...). This was compounded by some rather goofy fieldnames in the fetched json file, which can be fixed via structtags, see godoc.



            The code below parsed the json successfully. If you've further questions, let me know.



            package main

            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type Tracks struct {
            Toptracks Toptracks_info
            }

            type Toptracks_info struct {
            Track Track_info
            Attr Attr_info `json: "@attr"`
            }

            type Track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable Streamable_info
            Artist Artist_info
            Attr Track_attr_info `json: "@attr"`
            }

            type Attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type Streamable_info struct {
            Text string `json: "#text"`
            Fulltrack string
            }

            type Artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type Track_attr_info struct {
            Rank string
            }

            func perror(err error) {
            if err != nil {
            panic(err)
            }
            }

            func get_content() {
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)
            perror(err)
            defer res.Body.Close()

            decoder := json.NewDecoder(res.Body)
            var data Tracks
            err = decoder.Decode(&data)
            if err != nil {
            fmt.Printf("%Tn%sn%#vn",err, err, err)
            switch v := err.(type){
            case *json.SyntaxError:
            fmt.Println(string(body[v.Offset-40:v.Offset]))
            }
            }
            for i, track := range data.Toptracks.Track{
            fmt.Printf("%d: %s %sn", i, track.Artist.Name, track.Name)
            }
            }

            func main() {
            get_content()
            }





            share|improve this answer





















            • 1





              There is something in the response body.

              – peterSO
              Jun 17 '13 at 23:28






            • 4





              In my case, I was missing UPPER-CASE first character in the "struct" fields.

              – abourget
              Jun 8 '14 at 19:30











            • Answer below is right, using a Decoder directly on the response.Body avoids unnecessary allocations and is generally more ideomatic. Corrected my answer, thanks for pointing it out.

              – tike
              Dec 12 '15 at 18:30











            • @abourget omg thank you for this comment. Just spend 1 hours looking for problems in parser, confirming with wireshark that response is correct... thanks

              – agilob
              Mar 26 '17 at 20:15
















            21














            Your Problem were the slice declarations in your data structs (except for Track, they shouldn't be slices...). This was compounded by some rather goofy fieldnames in the fetched json file, which can be fixed via structtags, see godoc.



            The code below parsed the json successfully. If you've further questions, let me know.



            package main

            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type Tracks struct {
            Toptracks Toptracks_info
            }

            type Toptracks_info struct {
            Track Track_info
            Attr Attr_info `json: "@attr"`
            }

            type Track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable Streamable_info
            Artist Artist_info
            Attr Track_attr_info `json: "@attr"`
            }

            type Attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type Streamable_info struct {
            Text string `json: "#text"`
            Fulltrack string
            }

            type Artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type Track_attr_info struct {
            Rank string
            }

            func perror(err error) {
            if err != nil {
            panic(err)
            }
            }

            func get_content() {
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)
            perror(err)
            defer res.Body.Close()

            decoder := json.NewDecoder(res.Body)
            var data Tracks
            err = decoder.Decode(&data)
            if err != nil {
            fmt.Printf("%Tn%sn%#vn",err, err, err)
            switch v := err.(type){
            case *json.SyntaxError:
            fmt.Println(string(body[v.Offset-40:v.Offset]))
            }
            }
            for i, track := range data.Toptracks.Track{
            fmt.Printf("%d: %s %sn", i, track.Artist.Name, track.Name)
            }
            }

            func main() {
            get_content()
            }





            share|improve this answer





















            • 1





              There is something in the response body.

              – peterSO
              Jun 17 '13 at 23:28






            • 4





              In my case, I was missing UPPER-CASE first character in the "struct" fields.

              – abourget
              Jun 8 '14 at 19:30











            • Answer below is right, using a Decoder directly on the response.Body avoids unnecessary allocations and is generally more ideomatic. Corrected my answer, thanks for pointing it out.

              – tike
              Dec 12 '15 at 18:30











            • @abourget omg thank you for this comment. Just spend 1 hours looking for problems in parser, confirming with wireshark that response is correct... thanks

              – agilob
              Mar 26 '17 at 20:15














            21












            21








            21







            Your Problem were the slice declarations in your data structs (except for Track, they shouldn't be slices...). This was compounded by some rather goofy fieldnames in the fetched json file, which can be fixed via structtags, see godoc.



            The code below parsed the json successfully. If you've further questions, let me know.



            package main

            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type Tracks struct {
            Toptracks Toptracks_info
            }

            type Toptracks_info struct {
            Track Track_info
            Attr Attr_info `json: "@attr"`
            }

            type Track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable Streamable_info
            Artist Artist_info
            Attr Track_attr_info `json: "@attr"`
            }

            type Attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type Streamable_info struct {
            Text string `json: "#text"`
            Fulltrack string
            }

            type Artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type Track_attr_info struct {
            Rank string
            }

            func perror(err error) {
            if err != nil {
            panic(err)
            }
            }

            func get_content() {
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)
            perror(err)
            defer res.Body.Close()

            decoder := json.NewDecoder(res.Body)
            var data Tracks
            err = decoder.Decode(&data)
            if err != nil {
            fmt.Printf("%Tn%sn%#vn",err, err, err)
            switch v := err.(type){
            case *json.SyntaxError:
            fmt.Println(string(body[v.Offset-40:v.Offset]))
            }
            }
            for i, track := range data.Toptracks.Track{
            fmt.Printf("%d: %s %sn", i, track.Artist.Name, track.Name)
            }
            }

            func main() {
            get_content()
            }





            share|improve this answer















            Your Problem were the slice declarations in your data structs (except for Track, they shouldn't be slices...). This was compounded by some rather goofy fieldnames in the fetched json file, which can be fixed via structtags, see godoc.



            The code below parsed the json successfully. If you've further questions, let me know.



            package main

            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type Tracks struct {
            Toptracks Toptracks_info
            }

            type Toptracks_info struct {
            Track Track_info
            Attr Attr_info `json: "@attr"`
            }

            type Track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable Streamable_info
            Artist Artist_info
            Attr Track_attr_info `json: "@attr"`
            }

            type Attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type Streamable_info struct {
            Text string `json: "#text"`
            Fulltrack string
            }

            type Artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type Track_attr_info struct {
            Rank string
            }

            func perror(err error) {
            if err != nil {
            panic(err)
            }
            }

            func get_content() {
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)
            perror(err)
            defer res.Body.Close()

            decoder := json.NewDecoder(res.Body)
            var data Tracks
            err = decoder.Decode(&data)
            if err != nil {
            fmt.Printf("%Tn%sn%#vn",err, err, err)
            switch v := err.(type){
            case *json.SyntaxError:
            fmt.Println(string(body[v.Offset-40:v.Offset]))
            }
            }
            for i, track := range data.Toptracks.Track{
            fmt.Printf("%d: %s %sn", i, track.Artist.Name, track.Name)
            }
            }

            func main() {
            get_content()
            }






            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited Jul 7 '16 at 16:04









            Myles McDonnell

            6,61184679




            6,61184679










            answered Jun 17 '13 at 22:10









            tiketike

            1,666817




            1,666817








            • 1





              There is something in the response body.

              – peterSO
              Jun 17 '13 at 23:28






            • 4





              In my case, I was missing UPPER-CASE first character in the "struct" fields.

              – abourget
              Jun 8 '14 at 19:30











            • Answer below is right, using a Decoder directly on the response.Body avoids unnecessary allocations and is generally more ideomatic. Corrected my answer, thanks for pointing it out.

              – tike
              Dec 12 '15 at 18:30











            • @abourget omg thank you for this comment. Just spend 1 hours looking for problems in parser, confirming with wireshark that response is correct... thanks

              – agilob
              Mar 26 '17 at 20:15














            • 1





              There is something in the response body.

              – peterSO
              Jun 17 '13 at 23:28






            • 4





              In my case, I was missing UPPER-CASE first character in the "struct" fields.

              – abourget
              Jun 8 '14 at 19:30











            • Answer below is right, using a Decoder directly on the response.Body avoids unnecessary allocations and is generally more ideomatic. Corrected my answer, thanks for pointing it out.

              – tike
              Dec 12 '15 at 18:30











            • @abourget omg thank you for this comment. Just spend 1 hours looking for problems in parser, confirming with wireshark that response is correct... thanks

              – agilob
              Mar 26 '17 at 20:15








            1




            1





            There is something in the response body.

            – peterSO
            Jun 17 '13 at 23:28





            There is something in the response body.

            – peterSO
            Jun 17 '13 at 23:28




            4




            4





            In my case, I was missing UPPER-CASE first character in the "struct" fields.

            – abourget
            Jun 8 '14 at 19:30





            In my case, I was missing UPPER-CASE first character in the "struct" fields.

            – abourget
            Jun 8 '14 at 19:30













            Answer below is right, using a Decoder directly on the response.Body avoids unnecessary allocations and is generally more ideomatic. Corrected my answer, thanks for pointing it out.

            – tike
            Dec 12 '15 at 18:30





            Answer below is right, using a Decoder directly on the response.Body avoids unnecessary allocations and is generally more ideomatic. Corrected my answer, thanks for pointing it out.

            – tike
            Dec 12 '15 at 18:30













            @abourget omg thank you for this comment. Just spend 1 hours looking for problems in parser, confirming with wireshark that response is correct... thanks

            – agilob
            Mar 26 '17 at 20:15





            @abourget omg thank you for this comment. Just spend 1 hours looking for problems in parser, confirming with wireshark that response is correct... thanks

            – agilob
            Mar 26 '17 at 20:15











            12














            You need upper case property names in your structs in order to be used by the json packages.



            Upper case property names are exported properties. Lower case property names are not exported.



            You also need to pass the your data object by reference (&data).



            package main

            import "os"
            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type tracks struct {
            Toptracks toptracks_info
            }

            type toptracks_info struct {
            Track track_info
            Attr attr_info
            }

            type track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable streamable_info
            Artist artist_info
            Attr track_attr_info
            }

            type attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type streamable_info struct {
            Text string
            Fulltrack string
            }

            type artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type track_attr_info struct {
            Rank string
            }

            func get_content() {
            // json data
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)

            if err != nil {
            panic(err.Error())
            }

            body, err := ioutil.ReadAll(res.Body)

            if err != nil {
            panic(err.Error())
            }

            var data tracks
            json.Unmarshal(body, &data)
            fmt.Printf("Results: %vn", data)
            os.Exit(0)
            }

            func main() {
            get_content()
            }





            share|improve this answer


























            • still not work, is this working for you ? same empty response

              – Akshay
              Jun 17 '13 at 20:47








            • 2





              thanks for "You need upper case property names in your structs in order to be used by the json packages."

              – HVNSweeting
              Apr 28 '15 at 10:06
















            12














            You need upper case property names in your structs in order to be used by the json packages.



            Upper case property names are exported properties. Lower case property names are not exported.



            You also need to pass the your data object by reference (&data).



            package main

            import "os"
            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type tracks struct {
            Toptracks toptracks_info
            }

            type toptracks_info struct {
            Track track_info
            Attr attr_info
            }

            type track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable streamable_info
            Artist artist_info
            Attr track_attr_info
            }

            type attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type streamable_info struct {
            Text string
            Fulltrack string
            }

            type artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type track_attr_info struct {
            Rank string
            }

            func get_content() {
            // json data
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)

            if err != nil {
            panic(err.Error())
            }

            body, err := ioutil.ReadAll(res.Body)

            if err != nil {
            panic(err.Error())
            }

            var data tracks
            json.Unmarshal(body, &data)
            fmt.Printf("Results: %vn", data)
            os.Exit(0)
            }

            func main() {
            get_content()
            }





            share|improve this answer


























            • still not work, is this working for you ? same empty response

              – Akshay
              Jun 17 '13 at 20:47








            • 2





              thanks for "You need upper case property names in your structs in order to be used by the json packages."

              – HVNSweeting
              Apr 28 '15 at 10:06














            12












            12








            12







            You need upper case property names in your structs in order to be used by the json packages.



            Upper case property names are exported properties. Lower case property names are not exported.



            You also need to pass the your data object by reference (&data).



            package main

            import "os"
            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type tracks struct {
            Toptracks toptracks_info
            }

            type toptracks_info struct {
            Track track_info
            Attr attr_info
            }

            type track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable streamable_info
            Artist artist_info
            Attr track_attr_info
            }

            type attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type streamable_info struct {
            Text string
            Fulltrack string
            }

            type artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type track_attr_info struct {
            Rank string
            }

            func get_content() {
            // json data
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)

            if err != nil {
            panic(err.Error())
            }

            body, err := ioutil.ReadAll(res.Body)

            if err != nil {
            panic(err.Error())
            }

            var data tracks
            json.Unmarshal(body, &data)
            fmt.Printf("Results: %vn", data)
            os.Exit(0)
            }

            func main() {
            get_content()
            }





            share|improve this answer















            You need upper case property names in your structs in order to be used by the json packages.



            Upper case property names are exported properties. Lower case property names are not exported.



            You also need to pass the your data object by reference (&data).



            package main

            import "os"
            import "fmt"
            import "net/http"
            import "io/ioutil"
            import "encoding/json"

            type tracks struct {
            Toptracks toptracks_info
            }

            type toptracks_info struct {
            Track track_info
            Attr attr_info
            }

            type track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable streamable_info
            Artist artist_info
            Attr track_attr_info
            }

            type attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type streamable_info struct {
            Text string
            Fulltrack string
            }

            type artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type track_attr_info struct {
            Rank string
            }

            func get_content() {
            // json data
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"

            res, err := http.Get(url)

            if err != nil {
            panic(err.Error())
            }

            body, err := ioutil.ReadAll(res.Body)

            if err != nil {
            panic(err.Error())
            }

            var data tracks
            json.Unmarshal(body, &data)
            fmt.Printf("Results: %vn", data)
            os.Exit(0)
            }

            func main() {
            get_content()
            }






            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited Jun 17 '13 at 20:47

























            answered Jun 17 '13 at 20:42









            DanielDaniel

            29.7k67368




            29.7k67368













            • still not work, is this working for you ? same empty response

              – Akshay
              Jun 17 '13 at 20:47








            • 2





              thanks for "You need upper case property names in your structs in order to be used by the json packages."

              – HVNSweeting
              Apr 28 '15 at 10:06



















            • still not work, is this working for you ? same empty response

              – Akshay
              Jun 17 '13 at 20:47








            • 2





              thanks for "You need upper case property names in your structs in order to be used by the json packages."

              – HVNSweeting
              Apr 28 '15 at 10:06

















            still not work, is this working for you ? same empty response

            – Akshay
            Jun 17 '13 at 20:47







            still not work, is this working for you ? same empty response

            – Akshay
            Jun 17 '13 at 20:47






            2




            2





            thanks for "You need upper case property names in your structs in order to be used by the json packages."

            – HVNSweeting
            Apr 28 '15 at 10:06





            thanks for "You need upper case property names in your structs in order to be used by the json packages."

            – HVNSweeting
            Apr 28 '15 at 10:06











            6














            The results from json.Unmarshal (into var data interface{}) do not directly match your Go type and variable declarations. For example,



            package main

            import (
            "encoding/json"
            "fmt"
            "io/ioutil"
            "net/http"
            "os"
            )

            type Tracks struct {
            Toptracks Toptracks_info
            }

            type Toptracks_info struct {
            Track Track_info
            Attr Attr_info
            }

            type Track_info struct {
            Name string
            Duration string
            Listeners string
            Mbid string
            Url string
            Streamable Streamable_info
            Artist Artist_info
            Attr Track_attr_info
            }

            type Attr_info struct {
            Country string
            Page string
            PerPage string
            TotalPages string
            Total string
            }

            type Streamable_info struct {
            Text string
            Fulltrack string
            }

            type Artist_info struct {
            Name string
            Mbid string
            Url string
            }

            type Track_attr_info struct {
            Rank string
            }

            func get_content() {
            // json data
            url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"
            url += "&limit=1" // limit data for testing
            res, err := http.Get(url)
            if err != nil {
            panic(err.Error())
            }
            body, err := ioutil.ReadAll(res.Body)
            if err != nil {
            panic(err.Error())
            }
            var data interface{} // TopTracks
            err = json.Unmarshal(body, &data)
            if err != nil {
            panic(err.Error())
            }
            fmt.Printf("Results: %vn", data)
            os.Exit(0)
            }

            func main() {
            get_content()
            }


            Output:



            Results: map[toptracks:map[track:map[name:Get Lucky (feat. Pharrell Williams) listeners:1863 url:http://www.last.fm/music/Daft+Punk/_/Get+Lucky+(feat.+Pharrell+Williams) artist:map[name:Daft Punk mbid:056e4f3e-d505-4dad-8ec1-d04f521cbb56 url:http://www.last.fm/music/Daft+Punk] image:[map[#text:http://userserve-ak.last.fm/serve/34s/88137413.png size:small] map[#text:http://userserve-ak.last.fm/serve/64s/88137413.png size:medium] map[#text:http://userserve-ak.last.fm/serve/126/88137413.png size:large] map[#text:http://userserve-ak.last.fm/serve/300x300/88137413.png size:extralarge]] @attr:map[rank:1] duration:369 mbid: streamable:map[#text:1 fulltrack:0]] @attr:map[country:Netherlands page:1 perPage:1 totalPages:500 total:500]]]





            share|improve this answer




























              6














              The results from json.Unmarshal (into var data interface{}) do not directly match your Go type and variable declarations. For example,



              package main

              import (
              "encoding/json"
              "fmt"
              "io/ioutil"
              "net/http"
              "os"
              )

              type Tracks struct {
              Toptracks Toptracks_info
              }

              type Toptracks_info struct {
              Track Track_info
              Attr Attr_info
              }

              type Track_info struct {
              Name string
              Duration string
              Listeners string
              Mbid string
              Url string
              Streamable Streamable_info
              Artist Artist_info
              Attr Track_attr_info
              }

              type Attr_info struct {
              Country string
              Page string
              PerPage string
              TotalPages string
              Total string
              }

              type Streamable_info struct {
              Text string
              Fulltrack string
              }

              type Artist_info struct {
              Name string
              Mbid string
              Url string
              }

              type Track_attr_info struct {
              Rank string
              }

              func get_content() {
              // json data
              url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"
              url += "&limit=1" // limit data for testing
              res, err := http.Get(url)
              if err != nil {
              panic(err.Error())
              }
              body, err := ioutil.ReadAll(res.Body)
              if err != nil {
              panic(err.Error())
              }
              var data interface{} // TopTracks
              err = json.Unmarshal(body, &data)
              if err != nil {
              panic(err.Error())
              }
              fmt.Printf("Results: %vn", data)
              os.Exit(0)
              }

              func main() {
              get_content()
              }


              Output:



              Results: map[toptracks:map[track:map[name:Get Lucky (feat. Pharrell Williams) listeners:1863 url:http://www.last.fm/music/Daft+Punk/_/Get+Lucky+(feat.+Pharrell+Williams) artist:map[name:Daft Punk mbid:056e4f3e-d505-4dad-8ec1-d04f521cbb56 url:http://www.last.fm/music/Daft+Punk] image:[map[#text:http://userserve-ak.last.fm/serve/34s/88137413.png size:small] map[#text:http://userserve-ak.last.fm/serve/64s/88137413.png size:medium] map[#text:http://userserve-ak.last.fm/serve/126/88137413.png size:large] map[#text:http://userserve-ak.last.fm/serve/300x300/88137413.png size:extralarge]] @attr:map[rank:1] duration:369 mbid: streamable:map[#text:1 fulltrack:0]] @attr:map[country:Netherlands page:1 perPage:1 totalPages:500 total:500]]]





              share|improve this answer


























                6












                6








                6







                The results from json.Unmarshal (into var data interface{}) do not directly match your Go type and variable declarations. For example,



                package main

                import (
                "encoding/json"
                "fmt"
                "io/ioutil"
                "net/http"
                "os"
                )

                type Tracks struct {
                Toptracks Toptracks_info
                }

                type Toptracks_info struct {
                Track Track_info
                Attr Attr_info
                }

                type Track_info struct {
                Name string
                Duration string
                Listeners string
                Mbid string
                Url string
                Streamable Streamable_info
                Artist Artist_info
                Attr Track_attr_info
                }

                type Attr_info struct {
                Country string
                Page string
                PerPage string
                TotalPages string
                Total string
                }

                type Streamable_info struct {
                Text string
                Fulltrack string
                }

                type Artist_info struct {
                Name string
                Mbid string
                Url string
                }

                type Track_attr_info struct {
                Rank string
                }

                func get_content() {
                // json data
                url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"
                url += "&limit=1" // limit data for testing
                res, err := http.Get(url)
                if err != nil {
                panic(err.Error())
                }
                body, err := ioutil.ReadAll(res.Body)
                if err != nil {
                panic(err.Error())
                }
                var data interface{} // TopTracks
                err = json.Unmarshal(body, &data)
                if err != nil {
                panic(err.Error())
                }
                fmt.Printf("Results: %vn", data)
                os.Exit(0)
                }

                func main() {
                get_content()
                }


                Output:



                Results: map[toptracks:map[track:map[name:Get Lucky (feat. Pharrell Williams) listeners:1863 url:http://www.last.fm/music/Daft+Punk/_/Get+Lucky+(feat.+Pharrell+Williams) artist:map[name:Daft Punk mbid:056e4f3e-d505-4dad-8ec1-d04f521cbb56 url:http://www.last.fm/music/Daft+Punk] image:[map[#text:http://userserve-ak.last.fm/serve/34s/88137413.png size:small] map[#text:http://userserve-ak.last.fm/serve/64s/88137413.png size:medium] map[#text:http://userserve-ak.last.fm/serve/126/88137413.png size:large] map[#text:http://userserve-ak.last.fm/serve/300x300/88137413.png size:extralarge]] @attr:map[rank:1] duration:369 mbid: streamable:map[#text:1 fulltrack:0]] @attr:map[country:Netherlands page:1 perPage:1 totalPages:500 total:500]]]





                share|improve this answer













                The results from json.Unmarshal (into var data interface{}) do not directly match your Go type and variable declarations. For example,



                package main

                import (
                "encoding/json"
                "fmt"
                "io/ioutil"
                "net/http"
                "os"
                )

                type Tracks struct {
                Toptracks Toptracks_info
                }

                type Toptracks_info struct {
                Track Track_info
                Attr Attr_info
                }

                type Track_info struct {
                Name string
                Duration string
                Listeners string
                Mbid string
                Url string
                Streamable Streamable_info
                Artist Artist_info
                Attr Track_attr_info
                }

                type Attr_info struct {
                Country string
                Page string
                PerPage string
                TotalPages string
                Total string
                }

                type Streamable_info struct {
                Text string
                Fulltrack string
                }

                type Artist_info struct {
                Name string
                Mbid string
                Url string
                }

                type Track_attr_info struct {
                Rank string
                }

                func get_content() {
                // json data
                url := "http://ws.audioscrobbler.com/2.0/?method=geo.gettoptracks&api_key=c1572082105bd40d247836b5c1819623&format=json&country=Netherlands"
                url += "&limit=1" // limit data for testing
                res, err := http.Get(url)
                if err != nil {
                panic(err.Error())
                }
                body, err := ioutil.ReadAll(res.Body)
                if err != nil {
                panic(err.Error())
                }
                var data interface{} // TopTracks
                err = json.Unmarshal(body, &data)
                if err != nil {
                panic(err.Error())
                }
                fmt.Printf("Results: %vn", data)
                os.Exit(0)
                }

                func main() {
                get_content()
                }


                Output:



                Results: map[toptracks:map[track:map[name:Get Lucky (feat. Pharrell Williams) listeners:1863 url:http://www.last.fm/music/Daft+Punk/_/Get+Lucky+(feat.+Pharrell+Williams) artist:map[name:Daft Punk mbid:056e4f3e-d505-4dad-8ec1-d04f521cbb56 url:http://www.last.fm/music/Daft+Punk] image:[map[#text:http://userserve-ak.last.fm/serve/34s/88137413.png size:small] map[#text:http://userserve-ak.last.fm/serve/64s/88137413.png size:medium] map[#text:http://userserve-ak.last.fm/serve/126/88137413.png size:large] map[#text:http://userserve-ak.last.fm/serve/300x300/88137413.png size:extralarge]] @attr:map[rank:1] duration:369 mbid: streamable:map[#text:1 fulltrack:0]] @attr:map[country:Netherlands page:1 perPage:1 totalPages:500 total:500]]]






                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Jun 17 '13 at 23:41









                peterSOpeterSO

                99.1k16169184




                99.1k16169184






























                    draft saved

                    draft discarded




















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f17156371%2fhow-to-get-json-response-in-golang%23new-answer', 'question_page');
                    }
                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Xamarin.iOS Cant Deploy on Iphone

                    Glorious Revolution

                    Dulmage-Mendelsohn matrix decomposition in Python