Class JsonUtils

java.lang.Object
com.google.gwt.core.client.JsonUtils

public class JsonUtils extends Object
Provides JSON-related utility methods.
  • Method Details

    • stringify

      public static String stringify(JavaScriptObject obj)
      Converts a value to JSON.
    • stringify

      public static String stringify(JavaScriptObject obj, String space)
      Converts a value to JSON.
      Parameters:
      space - controls the spacing in the final string. Successive levels in the stringification will each be indented by this string (or the first ten characters of it).
    • escapeJsonForEval

      public static String escapeJsonForEval(String toEscape)
      Escapes characters within a JSON string than cannot be passed directly to eval(). Control characters, quotes and backslashes are not affected.
    • escapeValue

      public static String escapeValue(String toEscape)
      Returns a quoted, escaped JSON String.
    • safeEval

      public static <T extends JavaScriptObject> T safeEval(String json)
      Evaluates a JSON expression safely. The payload must evaluate to an Object or an Array (not a primitive or a String).
      Type Parameters:
      T - The type of JavaScriptObject that should be returned
      Parameters:
      json - The source JSON text
      Returns:
      The evaluated object
      Throws:
      IllegalArgumentException - if the input is not valid JSON
    • safeToEval

      public static boolean safeToEval(String text)
      Returns true if the given JSON string may be safely evaluated by eval() without undesired side effects or security risks. Note that a true result from this method does not guarantee that the input string is valid JSON. This method does not consider the contents of quoted strings; it may still be necessary to perform escaping prior to evaluation for correct results.

      The technique used is taken from RFC 4627.

      Note that this function may fail in sufficiently large text in some browsers (e.g. Chrome). It is always better to use safeEval(java.lang.String) instead which is safer, faster and also works with large texts but less lenient than this one for invalid JSON.

    • unsafeEval

      public static <T extends JavaScriptObject> T unsafeEval(String json)
      Evaluates a JSON expression using eval(). This method does not validate the JSON text and should only be used on JSON from trusted sources. The payload must evaluate to an Object or an Array (not a primitive or a String).
      Type Parameters:
      T - The type of JavaScriptObject that should be returned
      Parameters:
      json - The source JSON text
      Returns:
      The evaluated object
    • throwIllegalArgumentException

      static void throwIllegalArgumentException(String message, String data)