Ok so today we will be looking into the Json parsing. Json is "Javascript Object Notation" a new form of format which is widle used over the http responce in webservices. It is structured and can contain data in human readable format.
To make json data salesforce provide some standard class called as System.JSON. We will be using this class to parse and then un parse the data in json.
Parsing:
To make json data salesforce provide some standard class called as System.JSON. We will be using this class to parse and then un parse the data in json.
Parsing:
- Create a visualforce page with controller.
- Now copy this code to make a wrapper class holding name,id and phone fields
//Subclass : Wrapper Class public class Accountwrap { //Static Variables public string id; public string name; public string Phone; //Wrapper Class Controller Accountwrap(string Phone, string name, string id) { this.Phone = Phone; this.name = name; this.id = id; } }
- Now to parse this wrapper class list into a json string use this code.
public void getlstAccount(){ List < Accountwrap > lstwrap = new List < Accountwrap > (); List < account > lstacc = [SELECT Id, Name, Phone FROM Account limit 2]; for (Account a: lstacc) { Accountwrap awrap = new Accountwrap(a.Phone,a.name,a.id); lstwrap.add(awrap); } strJson = JSON.serialize(lstwrap); }
- strJson is a public string and will get the json string,
Un-Parsing:
- To convert the json string we will use the same wrapper class to provide structure to the values.
- To un parse the string use this code
public static List<Accountwrap> parse(String str) { system.debug('*****str*****'+str ); JSONParser parser = JSON.createParser(str); system.debug('*****parse*****'+parser ); List<Accountwrap> jsonstatLst = new List<Accountwrap> (); while (parser.nextToken() != null) { System.debug('Current token: ' + parser.getCurrentToken() + '****JSONToken.START_ARRAY****'+JSONToken.START_ARRAY); if (parser.getCurrentToken() == JSONToken.START_ARRAY) { while (parser.nextToken() != null) { // Advance to the start object marker to // find next invoice statement object. if (parser.getCurrentToken() == JSONToken.START_OBJECT) { jsonstatLst.add((Accountwrap)parser.readValueAs(Accountwrap.class)); parser.skipChildren(); } } } } return jsonstatLst; }
- jsonstatLst is a List of type wrapper class and the method can populate any list of the same type with data in wrapper object form.
Hope this helps you!!