Module: ActiveSupport::JSON
| Relationships & Source Files | |
| Defined in: | activesupport/lib/active_support/json/decoding.rb, activesupport/lib/active_support/json/encoding.rb  | 
    
Constant Summary
- 
    DATETIME_REGEX =
    
# File 'activesupport/lib/active_support/json/decoding.rb', line 14/\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/ - 
    DATE_REGEX =
    # File 'activesupport/lib/active_support/json/decoding.rb', line 13
matches YAML-formatted dates
/\A\d{4}-\d{2}-\d{2}\z/ 
Class Method Summary
- 
    
      .decode(json)  
      (also: .load)
    
    
Parses a
JSONstring (JavaScript::ObjectNotation) into a hash. - 
    
      .dump(value, options = nil)  
    
    
Alias for .encode.
 - 
    
      .encode(value, options = nil)  
      (also: .dump)
    
    
Dumps objects in
JSON(JavaScript::ObjectNotation). - 
    
      .load(json)  
    
    
Alias for .decode.
 - 
    
      .parse_error  
    
    
Returns the class of the error that will be raised when there is an error in decoding
JSON. 
Class Method Details
.decode(json) Also known 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"}
  # File 'activesupport/lib/active_support/json/decoding.rb', line 22
def decode(json) data = ::JSON.parse(json, quirks_mode: true) if ActiveSupport.parse_json_times convert_dates_from(data) else data end end
.dump(value, options = nil)
Alias for .encode.
# File 'activesupport/lib/active_support/json/encoding.rb', line 43
alias_method :dump, :encode
.encode(value, options = nil) Also known as: .dump
Dumps objects in JSON (JavaScript ::Object Notation). See www.json.org for more info.
ActiveSupport::JSON.encode({ team: 'rails', players: '36' })
# => "{\"team\":\"rails\",\"players\":\"36\"}"
Generates JSON that is safe to include in JavaScript as it escapes U+2028 (Line Separator) and U+2029 (Paragraph Separator):
ActiveSupport::JSON.encode({ key: "\u2028" })
# => "{\"key\":\"\\u2028\"}"
By default, it also generates JSON that is safe to include in HTML, as it escapes <, >, and &:
ActiveSupport::JSON.encode({ key: "<>&" })
# => "{\"key\":\"\\u003c\\u003e\\u0026\"}"
This can be changed with the escape_html_entities option, or the global escape_html_entities_in_json configuration option.
ActiveSupport::JSON.encode({ key: "<>&" }, escape_html_entities: false)
# => "{\"key\":\"<>&\"}"
  # File 'activesupport/lib/active_support/json/encoding.rb', line 40
def encode(value, = nil) Encoding.json_encoder.new().encode(value) end
.load(json)
Alias for .decode.
# File 'activesupport/lib/active_support/json/decoding.rb', line 31
alias_method :load, :decode
.parse_error
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
  # File 'activesupport/lib/active_support/json/decoding.rb', line 43
def parse_error ::JSON::ParserError end