Skip to content

*NEW IMPLEMENTATIONS* for additional functionalities to the JSON package in Java.

License

Notifications You must be signed in to change notification settings

michael-c-nguyen/JSON-java

 
 

Repository files navigation

New Functionalities Added

Parsing Efficiency: (Target --> XML.java)

  • Increased efficiency in the XML.java class to support JSONObject lookups. Design effiecincy was achieved by utilizing the built-in parse function in the class. Once the object in question is found, parsing can stop. Thus, we do not need to read the entire object

Transformation of JSONObject Keys: (Target --> XML.java)

  • Added support to transform JSONObject keys when converting from XML to JSONObject by utilizing a functional programming style. A lambda function is passed as a parameter and the functional interface will accept the key and perform the desired transformation as a prefix, etc.

Stream JSONObject Values: (Target --> JSONObject.java)

  • Added support to call a toStream() method on JSONObject (this has not been developed yet). The spliterator API was utilized to recursively traverse each node of the JSONObject and apply stream operations on them.

Asynchronous Actions: (Target --> XML.java)

  • Added support for async call utilizing the CompletableFuture API. This allows the user to perform other tasks while the desired XML file is being tranformed to a JSONObject.

NOTE: All test cases were written with their respective class names.

NOTE: Please look for the keyword "Milestone" or "part" in the source code if you want to view where the updates were added.

Thank you for checking out the new functionalities. As always, please refer to the main repository for any official changes! The official documentation is described below.

Json-Java logo

image credit: Ismael Pérez Ortiz

JSON in Java [package org.json]

Maven Central

Click here if you just want the latest release jar file.

Overview

JSON is a light-weight language-independent data interchange format.

The JSON-Java package is a reference implementation that demonstrates how to parse JSON documents into Java objects and how to generate new JSON documents from the Java classes.

Project goals include:

  • Reliable and consistent results
  • Adherence to the JSON specification
  • Easy to build, use, and include in other projects
  • No external dependencies
  • Fast execution and low memory footprint
  • Maintain backward compatibility
  • Designed and tested to use on Java versions 1.6 - 1.11

The files in this package implement JSON encoders and decoders. The package can also convert between JSON and XML, HTTP headers, Cookies, and CDL.

The license includes this restriction: "The software shall be used for good, not evil." If your conscience cannot live with that, then choose a different package.

If you would like to contribute to this project

For more information on contributions, please see CONTRIBUTING.md

Bug fixes, code improvements, and unit test coverage changes are welcome! Because this project is currently in the maintenance phase, the kinds of changes that can be accepted are limited. For more information, please read the FAQ.

Build Instructions

The org.json package can be built from the command line, Maven, and Gradle. The unit tests can be executed from Maven, Gradle, or individually in an IDE e.g. Eclipse.

Building from the command line

Build the class files from the package root directory src/main/java

javac org/json/*.java

Create the jar file in the current directory

jar cf json-java.jar org/json/*.class

Compile a program that uses the jar (see example code below)

javac -cp .;json-java.jar Test.java (Windows)
javac -cp .:json-java.jar Test.java (Unix Systems)

Test file contents

import org.json.JSONObject;
public class Test {
    public static void main(String args[]){
       JSONObject jo = new JSONObject("{ \"abc\" : \"def\" }");
       System.out.println(jo.toString());
    }
}

Execute the Test file

java -cp .;json-java.jar Test (Windows)
java -cp .:json-java.jar Test (Unix Systems)

Expected output

{"abc":"def"}

Tools to build the package and execute the unit tests

Execute the test suite with Maven:

mvn clean test

Execute the test suite with Gradlew:

gradlew clean build test

Notes

For more information, please see NOTES.md

Files

For more information on files, please see FILES.md

Release history:

For the release history, please see RELEASES.md

About

*NEW IMPLEMENTATIONS* for additional functionalities to the JSON package in Java.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 100.0%