How to search/find In JSON with java

后端 未结 4 1771
忘了有多久
忘了有多久 2020-12-05 20:30

I have a below JSON string from the below i want to find/search criteria in JSON String.

1). To find the Number of keys present. 2). To get the values of given key(

相关标签:
4条回答
  • 2020-12-05 21:04

    Firstly, add json-path dependency in pom

    <dependency>
         <groupId>com.jayway.jsonpath</groupId>
         <artifactId>json-path</artifactId>
         <version>2.2.0</version>
    </dependency>
    

    Create a utility in Base Class that can be reused :

     public static String getValueFromJsonPath(String apiResponse, String jsonPath) {
            return JsonPath.read(apiResponse, jsonPath);
        }
    

    One example of using this method :

    getValueFromJsonPath(apiResponse, "$.store.book[0].category");
    

    NOTE : Create overloaded method with different return types depending upon the expected result (like List for fetching a list from json)

    0 讨论(0)
  • 2020-12-05 21:05

    I would try the following library

    https://github.com/jayway/JsonPath

    http://jsonpath.herokuapp.com/?path=%24.store.book[*]

    gives you all books

    0 讨论(0)
  • 2020-12-05 21:05

    First of all you have to add dependency

    <dependency>
        <groupId>org.json</groupId>
        <artifactId>json</artifactId>
        <version>20090211</version>
    </dependency>
    

    Then you can use this code:

    import org.json.JSONArray;
    import org.json.JSONException;
    import org.json.JSONObject;
    import org.json.XML;
    
    public class Main {
    
        public static int PRETTY_PRINT_INDENT_FACTOR = 4;
        public static String TEST_XML_STRING =
            "<Result><ResultParameters><ResultParameter><Key>TransEndDate</Key><Value>20170731</Value></ResultParameter><ResultParameter><Key>Failed Reason</Key><Value>Operator 03058361178\03058365278 has no permission to perform the Check Balance service.</Value></ResultParameter><ResultParameter><Key>TransEndTime</Key><Value>123611</Value></ResultParameter></ResultParameters><ResultCode>2000</ResultCode><ResultType>0</ResultType><OriginatorConversationID>S_X20130129210125</OriginatorConversationID><ResultDesc>Initiator authentication error.</ResultDesc><TransactionID>000749213589</TransactionID><ConversationID>AG_20170731_00004c28e51f1f822e9e</ConversationID></Result>";
    
        public static void main(String[] args) {
            try {
                JSONObject xmlJSONObj = XML.toJSONObject(TEST_XML_STRING);
                String jsonPrettyPrintString = xmlJSONObj.toString(PRETTY_PRINT_INDENT_FACTOR);
                System.out.println(jsonPrettyPrintString);
    
    
                System.out.println("Element="+xmlJSONObj.getJSONObject("Result").getInt("ResultCode"));
    
            } catch (JSONException je) {
                System.out.println(je.toString());
            }
        }
    }
    
    // in it i am searching an element which is present in a json object 
    
    0 讨论(0)
  • 2020-12-05 21:24

    You can also use the JsonPath project provided by REST Assured. This JsonPath project uses Groovy GPath expressions. In Maven you can depend on it like this:

    <dependency>
        <groupId>com.jayway.restassured</groupId>
        <artifactId>json-path</artifactId>
        <version>2.4.0</version>
    </dependency>
    

    Examples:

    To get a list of all book categories:

    List<String> categories = JsonPath.from(json).get("store.book.category");
    

    Get the first book category:

    String category = JsonPath.from(json).get("store.book[0].category");
    

    Get the last book category:

    String category = JsonPath.from(json).get("store.book[-1].category");
    

    Get all books with price between 5 and 15:

    List<Map> books = JsonPath.from(json).get("store.book.findAll { book -> book.price >= 5 && book.price <= 15 }");
    

    GPath is very powerful and you can make use of higher order functions and all Groovy data structures in your path expressions.

    0 讨论(0)
提交回复
热议问题