views:

73

answers:

2

I have the following string from a REST JSON response: [{"uid":10512213, "name":"Bob"},{"uid":7208201, "name":"John"},{"uid":10570, "name":"Jim"},{"uid":1799657, "name":"Sally"}]

The rest response definition is from Facebook: FB REST Link

I am using Google App Engine + GAELYK which runs in Jetty.

What is the best way to convert the above into array of maps in Groovy on the Server. (This would probably have to recurse through the response)

I am looking for something easy that doesn't include a lot of libraries. (I dont have maven)

+1  A: 

JSON Arrays starts with a [ character and ends with a ] character. JSON object starts with a { and ends with }.

If you go to JSON.org, you can download JSONArray.java. Use that to create a JSON array. You then loop through the array for (int i = 0; i < array.length(); i++) and retrieve each JSON object by calling array.getJSONObject(i); which returns JSONObject. From there, get the respective attribute value, e.g. long uid = json.getLong("uid");

Hope this helps.

The Elite Gentleman
+3  A: 

Use JsonSlurper...

An example script to read that response would be:

@Grab('net.sf.json-lib:json-lib:2.3:jdk15')
import net.sf.json.groovy.JsonSlurper

// Example Response Data
def restResponse = '[{"uid":10512213, "name":"Bob"},{"uid":7208201, "name":"John"},{"uid":10570, "name":"Jim"},{"uid":1799657, "name":"Sally"}]'

// Parse the response
def list = new JsonSlurper().parseText( restResponse )

// Print them out to make sure
list.each { println it }

This outputs:

[uid:10512213, name:Bob]
[uid:7208201, name:John]
[uid:10570, name:Jim]
[uid:1799657, name:Sally]

As you can see, list is a list of Maps, so if you just wanted a list of the names for example, you could just do:

def names = list.name

To use this in your Gaelyk app, you should just need to download json-lib-2.3-jdk15.jar from here and do something similar (without the @Grab then, as you'll have the jar in your WEB-INF/lib folder.

--edit--

Looking around, found this page showing the dependencies for json-lib

The @Grab in the test script does a lot of background work for you

tim_yates
Does @Grab work in eclipse?
Tihom
I believe so...but it won't work on the app engine when you deploy your gaelyk app
tim_yates
The easiest process was to run the script above which downloaded the jars into the .groovy directory. (I had to download ivy to get @Grab to work) I then copied the jars to the lib directory.
Tihom
Good idea! Strange you had to download Ivy though...
tim_yates