Mass assignment vulnerability explained

Mass assignment is a computer vulnerability where an active record pattern in a web application is abused to modify data items that the user should not normally be allowed to access such as password, granted permissions, or administrator status.

Many web application frameworks offer an active record and object-relational mapping features, where external data in serialization formats is automatically converted on input into internal objects and, in turn, into database record fields. If the framework's interface for that conversion is too permissive and the application designer doesn't mark specific fields as immutable, it is possible to overwrite fields that were never intended to be modified from outside (e.g. admin permissions flag).[1]

These vulnerabilities have been found in applications written in Ruby on Rails,[2] ASP.NET MVC,[3] and Java Play framework.[4]

In 2012 mass assignment on Ruby on Rails allowed bypassing of mapping restrictions and resulted in proof of concept injection of unauthorized SSH public keys into user accounts at GitHub.[5] [6] Further vulnerabilities in Ruby on Rails allowed creation of internal objects through a specially crafted JSON structure.[7]

In ASP.NET Core mapping restriction can be declared using the [BindNever] attribute.[8]

See also

Notes and References

  1. Web site: CWE-915: Improperly Controlled Modification of Dynamically-Determined Object Attributes . NIST . Common Weakness Enumeration . February 27, 2013.
  2. Web site: Mass Assignment . Ruby On Rails Security Guide . February 27, 2013.
  3. Web site: Mass Assignment Vulnerability in ASP.NET MVC . IronsHay . February 27, 2013.
  4. Web site: Playframework, how to protect against Mass Assignment . 2014 . Alberto Souza.
  5. Web site: GitHub suspends member over 'mass-assignment' hack . ZDnet . 2012 . February 27, 2013.
  6. Web site: [SEC][ANN] Rails 3.2.12, 3.1.11, and 2.3.17 have been released! ]. January 7, 2016.
  7. Web site: Denial of Service and Unsafe Object Creation Vulnerability in JSON (CVE-2013-0269) . January 7, 2016.
  8. Web site: Model Binding in ASP.NET Core. tdykstra. docs.microsoft.com. 20 June 2023 .