Skip to Content Skip to Search

module ActiveSupport::JSON

Constants

/\A(?:\d{4}-\d{2}-\d{2}|\d{4}-\d{1,2}-\d{1,2}[T \t]+\d{1,2}:\d{2}:\d{2}(\.[0-9]*)?(([ \t]*)Z|[-+]\d{2}?(:\d{2})?)?)\z/

matches YAML-formatted dates

/\A\d{4}-\d{2}-\d{2}\z/

Attributes

[RW] escape_html_entities_in_json

If true, encode >, <, & as escaped unicode sequences (e.g. > as u003e) as a safety measure.

[R] json_encoder

Sets the encoder used by Rails to encode Ruby objects into JSON strings in +Object#to_json+ and ActiveSupport::JSON.encode.

[RW] time_precision

Sets the precision of encoded time values. Defaults to 3 (equivalent to millisecond precision)

[RW] use_standard_json_time_format

If true, use ISO 8601 format for dates and times. Otherwise, fall back to the Active Support legacy format.

Public class methods

Also aliased as: load.

Parses a JSON string (JavaScript Object Notation) into a hash. See www.json.org for more info.

ActiveSupport::JSON.decode("{\"team\":\"rails\",\"players\":\"36\"}")
=> {"team" => "rails", "players" => "36"}
Source code GitHub
# File activesupport/lib/active_support/json/decoding.rb, line 22
def decode(json, options = {})
  data = ::JSON.parse(json, options)

  if ActiveSupport.parse_json_times
    convert_dates_from(data)
  else
    data
  end
end

Alias for: encode.

Also aliased as: dump.

Source code GitHub
# File activesupport/lib/active_support/json/encoding.rb, line 22
def encode(value, options = nil)
  if options.nil?
    Encoding.encode_without_options(value)
  else
    Encoding.json_encoder.new(options).encode(value)
  end
end
Source code GitHub
# File activesupport/lib/active_support/json/encoding.rb, line 178
def json_encoder=(encoder)
  @json_encoder = encoder
  @encoder_without_options = encoder.new
end

Alias for: decode.

Returns the class of the error that will be raised when there is an error in decoding JSON. Using this method means you won’t directly depend on the ActiveSupport’s JSON implementation, in case it changes in the future.

begin
  obj = ActiveSupport::JSON.decode(some_string)
rescue ActiveSupport::JSON.parse_error
  Rails.logger.warn("Attempted to decode invalid JSON: #{some_string}")
end
Source code GitHub
# File activesupport/lib/active_support/json/decoding.rb, line 43
def parse_error
  ::JSON::ParserError
end

Definition files