Ruby on Rails
Original author(s) | David Heinemeier Hansson |
---|---|
Initial release | July 2004[1] |
Stable release | 7.2.1[2]
/ 22 August 2024 |
Repository | |
Written in | Web application framework |
License | MIT License |
Website | rubyonrails |
Ruby on Rails (simplified as Rails) is a
Ruby on Rails' emergence in 2005 greatly influenced web app development, through innovative features such as seamless database table creations, migrations, and scaffolding of views to enable rapid application development. Ruby on Rails' influence on other web frameworks remains apparent today, with many frameworks in other languages borrowing its ideas, including Django in Python; Catalyst in Perl; Laravel, CakePHP and Yii in PHP; Grails in Groovy; Phoenix in Elixir; Play in Scala; and Sails.js in Node.js.
Well-known sites that use Ruby on Rails include Airbnb, Crunchbase, Dribbble,[5] GitHub,[6] Twitch[7] and Shopify.
History
Rails version 2.3 was released on 15 March 2009, with major new developments in templates, engines, Rack and nested model forms. Templates enable the developer to generate a skeleton application with custom gems and configurations. Engines give developers the ability to reuse application pieces complete with routes, view paths and models. The Rack web server interface and Metal allow one to write optimized pieces of code that route around Action Controller.[10]
On 23 December 2008, Merb, another web application framework, was launched, and Ruby on Rails announced it would work with the Merb project to bring "the best ideas of Merb" into Rails 3, ending the "unnecessary duplication" across both communities.[11] Merb was merged with Rails as part of the Rails 3.0 release.[12][13]
Rails 3.1 was released on 31 August 2011, featuring Reversible Database Migrations, Asset Pipeline, Streaming,
Rails 3.2 was released on 20 January 2012 with a faster development mode and routing engine (also known as Journey engine), Automatic Query Explain and Tagged Logging.[15] Rails 3.2.x is the last version that supports Ruby 1.8.7.[16] Rails 3.2.12 supports Ruby 2.0.[17]
Rails 4.0 was released on 25 June 2013, introducing Russian Doll Caching, Turbolinks, Live Streaming as well as making Active Resource, Active Record Observer and other components optional by splitting them as gems.[18]
Rails 4.1 was released on 8 April 2014, introducing Spring, Variants, Enums, Mailer previews, and secrets.yml.[19]
Rails 4.2 was released on 19 December 2014, introducing Active Job, asynchronous emails, Adequate Record, Web Console, and foreign keys.[20]
Rails 5.0 was released on 30 June 2016, introducing Action Cable, API mode, and Turbolinks 5.[21]
Rails 5.0.0.1 was released on 10 August 2016, with Exclusive use of rails CLI over Rake and support for Ruby version 2.2.2 and above.
Rails 5.1 was released on 27 April 2017, introducing JavaScript integration changes (management of JavaScript dependencies from NPM via Yarn, optional compilation of JavaScript using Webpack, and a rewrite of Rails UJS to use vanilla JavaScript instead of depending on jQuery), system tests using Capybara, encrypted secrets, parameterized mailers, direct & resolved routes, and a unified form_with helper replacing the form_tag/form_for helpers.[22]
Rails 5.2 was released on 9 April 2018, introducing new features that include ActiveStorage, built-in Redis Cache Store, updated Rails Credentials and a new DSL that allows for configuring a Content Security Policy for an application.[23]
Rails 5.2.2 was released on 4 December 2018, introducing numerous bug fixes and several logic improvements.[24]
Rails 6.0 was released on 16 August 2019, making Webpack default, adding mailbox routing, a default online rich-text editor, parallel testing, multiple database support, mailer routing and a new autoloader.[25]
Rails 6.1 was released on 9 December 2020, adding per-database connection switching, horizontal database sharding, eager loading of all associations, Delegated Types as an alternative to single-table inheritance, asynchronous deletion of associations, error objects, and other improvements and bug fixes.[26]
Rails 7.0 was released on 15 December 2021, replacing Node.js and Webpack with import maps for JavaScript management by default, replacing Turbolinks with a combination of Turbo and Stimulus, adding at-work encryption into Active Record, using Zeitwerk exclusively for code loading, and more.[27]
Rails 7.1 was released on 5 October 2023, Dockerfiles support using Kamal in order to deploy your application, authentication improvements, and now including support for bun.[28]
Version | Release Date | Compatible Ruby Version(s)[29][30][31] |
---|---|---|
[32] | 1.013 December 2005 | 1.8.6 |
[33] | 1.219 January 2007 | 1.8.6 |
[34] | 2.07 December 2007 | 1.8.6 |
[35] | 2.131 May 2008 | 1.8.6 |
[36] | 2.221 November 2008 | 1.8.7 recommended; 1.8.6 possible |
[37] | 2.316 March 2009 | 1.8.7 recommended; 1.8.6 and 1.9.1 possible |
[38] | 3.029 August 2010 | 1.9.3 recommended; 1.8.7 and 1.9.2 possible |
[39] | 3.131 August 2011 | 1.9.3 recommended; 1.8.7 and 1.9.2 possible |
[40] | 3.220 January 2012 | 1.9.3 recommended; 1.8.7 and 1.9.2 possible |
[41] | 4.025 June 2013 | 2.0 preferred; 1.9.3 or newer required |
[19] | 4.18 April 2014 | 2.0 preferred; 1.9.3 or newer required |
[20] | 4.219 December 2014 | 2.0 preferred; 1.9.3 or newer required |
[21] | 5.030 June 2016 | 2.2.2 or newer |
[22] | 5.110 May 2017 | 2.2.2 or newer |
[23] | 5.29 April 2018 | 2.2.2 or newer |
[25] | 6.016 August 2019 | 2.5.0 or newer |
[26] | 6.19 December 2020 | 2.5.0 or newer |
[27] | 7.015 December 2021 | 2.7.0 or newer |
[42] | 7.15 October 2023 | 2.7.0 or newer |
[43] | 7.210 August 2024 | 3.1.0 or newer[44] |
[45] | 8.0Late 2024[46] | 3.3 or newer[47][48] |
Old version Older version, still maintained Latest version Future release |
Technical overview
Ruby on Rails evolves radically from release to release exploring the use of new technologies and adopting new standards on the Internet. Some features are very stable in Ruby on Rails while some are replaced in favour of new techniques.
Model-view-controller pattern
The model–view–controller (MVC) pattern is the fundamental structure to organize application programming.
In a default configuration, a model in the Ruby on Rails framework maps to a table in a database and to a Ruby file. For example, a model class User will usually be defined in the file 'user.rb' in the app/models directory, and linked to the table 'users' in the database. While developers are free to ignore this convention and choose differing names for their models, files, and database table, this is not common practice and is usually discouraged in accordance with the "convention-over-configuration" philosophy.[49]
A controller is a server-side component of Rails that responds to external requests from the web server to the application, by determining which view file to render. The controller may also have to query one or more models for information and pass these on to the view. For example, in an airline reservation system, a controller implementing a flight-search function would need to query a model representing individual flights to find flights matching the search, and might also need to query models representing airports and airlines to find related secondary data. The controller might then pass some subset of the flight data to the corresponding view, which would contain a mixture of static HTML and logic that use the flight data to create an HTML document containing a table with one row per flight. A controller may provide one or more actions. In Ruby on Rails, an action is typically a basic unit that describes how to respond to a specific external web-browser request. Also, note that the controller/action will be accessible for external web requests only if a corresponding route is mapped to it. Rails encourages developers to use
A view in the default configuration of Rails is an
Ruby on Rails includes tools that make common development tasks easier "out-of-the-box", such as scaffolding that can automatically construct some of the models and views needed for a basic website.[50] Also included are WEBrick, a simple Ruby web server that is distributed with Ruby, and Rake, a build system, distributed as a gem. Together with Ruby on Rails, these tools provide a basic development environment.[citation needed]
HTTP Servers
Ruby on Rails is most commonly not connected to the Internet directly, but through some front-end
JavaScript
Ruby on Rails is also noteworthy for its extensive use of the
Ruby on Rails 3.0 separates the markup of the page (which defines the structure of the page) from scripting (which determines functionality or logic of the page).Web Services
Since version 2.0, Ruby on Rails offers both HTML and XML as standard output formats. The latter is the facility for RESTful web services.
CSS
Rails 3.1 introduced
Template
By default, the server uses
Ruby versions
Ruby on Rails 3.0 has been designed to work with Ruby 1.8.7, Ruby 1.9.2, and JRuby 1.5.2+; earlier versions are not supported.[54]
Ruby on Rails 3.2 is the last series of releases that support Ruby 1.8.7.
Framework structure
Ruby on Rails is separated into various packages, namely
Deployment
Ruby on Rails is often installed using
Ruby on Rails is typically deployed with a database server such as MySQL or PostgreSQL, and a web server such as Apache running the Phusion Passenger module.
Philosophy and design
Ruby on Rails is intended to emphasize
The Rails Doctrine is an enduring enabler that guides the philosophy, design, and implementation of the Ruby on Rails framework.
"Convention over Configuration" means a developer only needs to specify unconventional aspects of the application. For example, if there is a class Sale in the model, the corresponding table in the database is called sales by default. It is only if one deviates from this convention, such as calling the table "products sold", that the developer needs to write code regarding these names. Generally, Ruby on Rails conventions lead to less code and less repetition.[57]
"Don't repeat yourself" means that information is located in a single, unambiguous place. For example, using the ActiveRecord module of Rails, the developer does not need to specify database column names in class definitions. Instead, Ruby on Rails can retrieve this information from the database based on the class name.
"Fat models, skinny controllers" means that most of the application logic should be placed within the model while leaving the controller as light as possible.
HTML Over The Wire (Hotwire),[58][59] Conceptual compression,[60][61] and robust security[62] mark Rails 7.0's approach to the One person framework.[a]
Trademarks
In March 2007,
I only grant promotional use [of the Rails logo] for products I'm directly involved with. Such as books that I've been part of the development process for or conferences where I have a say in the execution. I would most definitely seek to enforce all the trademarks of Rails.[67]
The trademark of the logo was cancelled on 25 October 2019.[66]
Reception
Scalability
In earlier days, Rails running on
In 2011,
Security
In March 2012, security researcher Egor Homakov discovered a mass assignment vulnerability that allowed certain Rails applications to be remotely exploited, and demonstrated it by non-maliciously hacking GitHub after his earlier attempts at responsible disclosure were dismissed.[79]
On 24 September 2013, a session cookie persistence security flaw was reported in Ruby on Rails. In a default configuration, the entire session hash is stored within a session cookie known as CookieStore, allowing any authenticated session possessing the session cookie to log in as the target user at any time in the future. As a workaround, administrators are advised to configure cookies to be stored on the server using mechanisms such as ActiveRecordStore.[80]
Researchers Daniel Jackson and Joseph Near developed a data debugger they called "Space" that can analyze the data access of a Rails program and determine if the program properly adheres to rules regarding access restrictions. On 15 April 2016, Near reported that an analysis of 50 popular Web applications using Space uncovered 23 previously unknown security flaws.[81]
See also
Notes
References
- ^ "[ANN] Rails 0.5.0: The end of vaporware!". rubytalk.org. 24 July 2004. Archived from the original on 1 August 2024. Retrieved 1 August 2024.
- ^ "Release 7.2.1". 22 August 2024. Retrieved 27 August 2024.
- ^ "Release v6.0.3.4 · rails/rails · GitHub". GitHub. Archived from the original on 8 December 2021. Retrieved 16 December 2019.
- ^ "Getting Started with Rails: What Is Rails?". guides.rubyonrails.org. Archived from the original on 29 April 2016. Retrieved 10 August 2014.
- ^ Goswami, Shubham. "Django vs Ruby on Rails – The Choice for Mobile App Development". appsearch.org. Archived from the original on 31 January 2021. Retrieved 28 November 2020.
- IEEE. Archivedfrom the original on 9 November 2021. Retrieved 9 November 2021.
- ^ "Breaking the Monolith at Twitch: Part One".
- ^ Grimmer, Lenz−− (February 2006). "Interview with David Heinemeier Hansson from Ruby on Rails". MySQL AB. Archived from the original on 25 February 2013. Retrieved 8 June 2008.
- ^ Hansson, David (7 August 2006). "Ruby on Rails will ship with OS X 10.5 (Leopard)". weblog.rubyonrails.org. Archived from the original on 13 August 2006. Retrieved 8 June 2008.
- ^ Hansson, David (16 March 2009). "Rails 2.3: Templates, Engines, Rack, Metal, much more!". weblog.rubyonrails.org. Archived from the original on 21 March 2009. Retrieved 22 March 2009.
- ^ "The day Merb joined Rails". rubyonrails.org. 27 December 2008. Archived from the original on 9 February 2013.
- ^ "Ruby on Rails 3.0 Release Notes — Ruby on Rails Guides". edgeguides.rubyonrails.org. Retrieved 24 May 2017.
- ^ "Ruby on Rails 3.0 goes modular". sdtimes.com. 10 February 2010. Archived from the original on 24 September 2010. Retrieved 6 August 2010.
- ^ "Ruby on Rails 3.1 Release Notes". guides.rubyonrails.org. 1 September 2012. Archived from the original on 27 August 2012. Retrieved 3 September 2012.
- ^ "Ruby on Rails 3.2 Release Notes". guides.rubyonrails.org. 1 September 2012.
- ^ "Rails/master is now 4.0.0.beta". weblog.rubyonrails.org. 1 September 2012. Archived from the original on 3 September 2012. Retrieved 3 September 2012.
- ^ Rails 3.2.x is now compatible with Ruby 2.0.0 by sikachu · Pull Request #9406 · rails/rails · GitHub Archived 29 July 2017 at the Wayback Machine. Github.com. Retrieved on 2014-05-30.
- ^ "Rails 4.0: Final version released!". weblog.rubyonrails.org. 25 June 2013. Archived from the original on 27 April 2016. Retrieved 24 May 2017.
- ^ a b "Rails 4.1.0: Spring, Variants, Enums, Mailer previews, secrets.yml". weblog.rubyonrails.org. 8 April 2014. Archived from the original on 8 December 2015. Retrieved 8 April 2014.
- ^ a b "Rails 4.2: Active Job, Asynchronous Mails, Adequate Record, Web Console, Foreign Keys". weblog.rubyonrails.org. 19 December 2014. Archived from the original on 9 December 2015. Retrieved 5 December 2015.
- ^ a b "Rails 5.0: Action Cable, API mode, and so much more". weblog.rubyonrails.org. 30 June 2016. Archived from the original on 30 June 2016. Retrieved 19 November 2016.
- ^ a b "Rails 5.1: Loving JavaScript, System Tests, Encrypted Secrets, and more". weblog.rubyonrails.org. 27 April 2017. Archived from the original on 27 April 2017. Retrieved 10 May 2017.
- ^ a b "Rails 5.2.0 FINAL: Active Storage, Redis Cache Store, HTTP/2 Early Hints, CSP, Credentials". weblog.rubyonrails.org. 9 April 2018. Archived from the original on 26 July 2020. Retrieved 9 April 2018.
- ^ rafaelfranca (4 December 2018). "Rails 5.2.2 has been released!". weblog.rubyonrails.org. Archived from the original on 5 December 2018. Retrieved 4 January 2019.
- ^ a b dhh (19 August 2019). "Rails 6.0: Action Mailbox, Action Text, Multiple DBs, Parallel Testing, Webpacker by default, and Zeitwerk". weblog.rubyonrails.org. Archived from the original on 2 December 2019. Retrieved 12 November 2019.
- ^ a b eileencodes (9 December 2020). "Rails 6.1: Horizontal Sharding, Multi-DB Improvements, Strict Loading, Destroy Associations in Background, Error Objects, and more!". weblog.rubyonrails.org. Retrieved 28 December 2020.
- ^ a b dhh (15 December 2021). "Rails 7.0: Fulfilling a vision". weblog.rubyonrails.org. Retrieved 16 December 2021.
- ^ "Rails 7.1: Dockerfiles, BYO Authentication, More Async Queries, and more!". Ruby on Rails. Archived from the original on 5 October 2023. Retrieved 8 October 2023.
- ^ "Ruby/Rails Compatibility Matrix". devalot.com. Archived from the original on 18 August 2022. Retrieved 5 March 2021.
- ^ "Upgrading Ruby on Rails". guides.rubyonrails.org. Retrieved 5 March 2021.
- ^ "Upgrading Ruby on Rails". edgeguides.rubyonrails.org. Retrieved 5 March 2021.
- ^ "Rails 1.0: Party like it's one oh oh!" Archived 17 December 2015 at the Wayback Machine. weblog.rubyonrails.org. Retrieved 9 June 2010.
- ^ "Rails 1.2: REST admiration, HTTP lovefest, and UTF-8 celebrations" Archived 2012-11-02 at the Wayback Machine. weblog.rubyonrails.org. Retrieved 9 June 2010.
- ^ "Rails 2.0: It's done!" Archived 28 May 2010 at the Wayback Machine. weblog.rubyonrails.org. Retrieved 9 June 2010.
- ^ Rails 2.1: Time zones, dirty, caching, gem dependencies, caching, etc Archived 2012-11-02 at the Wayback Machine. weblog.rubyonrails.org. Retrieved 9 June 2010.
- ^ "Rails 2.2: i18n, HTTP validators, thread safety, JRuby/1.9 compatibility, docs" Archived 2 December 2008 at the Wayback Machine. weblog.rubyonrails.org. Retrieved 9 June 2010.
- ^ "Rails 2.3: Templates, Engines, Rack, Metal, much more!" Archived 21 March 2009 at the Wayback Machine. weblog.rubyonrails.org. Retrieved 9 June 2010.
- ^ "Rails 3.0: It's ready!" Archived 31 August 2010 at the Wayback Machine. weblog.rubyonrails.org. Retrieved 30 August 2010.
- ^ "bumping to 3.1.0". Github.com. Archived from the original on 19 June 2016. Retrieved 31 August 2011.
- ^ "Preparing for 3.2.0 release". Github.com. Archived from the original on 29 July 2017. Retrieved 22 January 2012.
- ^ "Rails 4 in 30'". blog.wyeworks.com. Archived from the original on 4 December 2012. Retrieved 15 December 2012.
- ^ França, Rafael. "Rails 7.1: Dockerfiles, BYO Authentication, More Async Queries, and more!". rubyonrails.org. Archived from the original on 5 October 2023. Retrieved 5 October 2023.
- ^ França, Rafael. "Development of Rails 7.2 starts now". GitHub. Archived from the original on 25 November 2023. Retrieved 26 September 2023.
- ^ https://rubyonrails.org/2024/8/10/Rails-7-2-0-has-been-released#other-improvements Archived 11 August 2024 at the Wayback Machine [bare URL]
- ^ Heinemeier Hansson, David. "8.0.0 Milestones". GitHub. Archived from the original on 27 December 2023. Retrieved 31 December 2023.
- ^ https://rubyonrails.org/2024/8/10/Rails-7-2-0-has-been-released#whats-next Archived 11 August 2024 at the Wayback Machine [bare URL]
- ^ França, Rafael (14 May 2024). "Reapply "Rails 8 will target Ruby 3.3+ only for new apps"". GitHub. Archived from the original on 18 May 2024. Retrieved 18 May 2024.
- ^ Vipul, A M (17 May 2024). "Start of Rails 8 development, 7.0.8.2 & 7.1.3.3 released, Kamal by default, and lots more!". weblog.rubyonrails.org. Archived from the original on 18 May 2024. Retrieved 18 May 2024.
- ^ "The Rails Doctrine". Ruby on Rails. Archived from the original on 8 February 2021. Retrieved 7 June 2024.
- ^ Sean Lynch (15 December 2007). "fairleads: Rails 2.0 and Scaffolding Step by Step". Fairleads.blogspot.com. Archived from the original on 29 May 2009. Retrieved 24 May 2017.
- ^ "Ruby on Rails: Deploy". rubyonrails.org. Archived from the original on 7 July 2009. Retrieved 3 December 2012.
- ^ Maxcer, Chris. "PowerRuby Brings Enterprise Ruby on Rails Support to IBM i". iPro Developer. Archived from the original on 9 October 2013. Retrieved 9 May 2014.
- ^ Js_Escape_Map. "ActionView::Helpers::JavaScriptHelper". Api.rubyonrails.org. Archived from the original on 22 July 2011. Retrieved 24 May 2017.
- ^ "Rails 3.0: It's ready!". weblog.rubyonrails.org. 29 August 2010. Archived from the original on 31 August 2010. Retrieved 30 August 2010.
Rails 3.0 has been designed to work with Ruby 1.8.7, Ruby 1.9.2, and JRuby 1.5.2+.
- ^ "Rails 3.2.0.rc2 has been released!". weblog.rubyonrails.org. 1 September 2012. Archived from the original on 1 September 2012. Retrieved 3 September 2012.
- ^ "Ruby on Rails: Download". rubyonrails.org. Archived from the original on 12 December 2009.
- ^ "Getting Started with Rails". guides.rubyonrails.org. Archived from the original on 29 April 2016. Retrieved 10 March 2014.
- ^ David Heinemeier Hansson (7 Dec 2021) The time is right for Hotwire Archived 20 December 2021 at the Wayback Machine
- ^ David Heinemeier Hansson (6 September 2021) Rails 7 will have three great answers to JavaScript in 2021+ Archived 20 December 2021 at the Wayback Machine
- ^ David Heinemeier Hansson (19 April 2018) Conceptual compression means beginners don’t need to know SQL — hallelujah! Archived 20 December 2021 at the Wayback Machine
- ^ David Heinemeier Hansson (15 May 2018) RailsConf 2018: Opening Keynote: FIXME by David Heinemeier Hansson Archived 20 December 2021 at the Wayback Machine Conceptual compression
- ^ David Heinemeier Hansson (31 Aug 2020) Serious security Archived 26 December 2021 at the Wayback Machine
- ^ David Heinemeier Hansson, creator of Ruby on Rails and hey.com (19 Dec 2021) Ruby on Rails Creator Touts 7.0 as One-Person Framework, 'The Way It Used To Be' Archived 20 December 2021 at the Wayback Machine
- USPTO. Archivedfrom the original on 14 October 2007. Retrieved 15 December 2021.
- USPTO. Archivedfrom the original on 15 October 2007. Retrieved 15 December 2021.
- ^ USPTO. Archivedfrom the original on 15 October 2007. Retrieved 15 December 2021.
- ^ a b Forde, Pete (23 July 2007). "Beginning Rails: From Novice to Professional". Archived from the original on 5 August 2007. Retrieved 1 August 2007.
- ^ Cooper, Peter (24 July 2007). "David Heinemeier Hansson says No to Use of Rails Logo". Archived from the original on 25 August 2017. Retrieved 1 August 2007.
- ^ "5 Question Interview with Twitter Developer Alex Payne". radicalbehavior.com. 29 March 2007. Archived from the original on 23 April 2009. Retrieved 4 November 2014.
By various metrics Twitter is the biggest Rails site on the net right now. Running on Rails has forced us to deal with scaling issues - issues that any growing site eventually contends with – far sooner than I think we would on another framework.
- ^ Steve Jenson; Alex Payne & Robey Pointer interview (3 April 2009). "Twitter on Scala". artima.com. Archived from the original on 19 June 2009. Retrieved 18 July 2009.
We had a Ruby-based queuing system that we used for communicating between the Rails front ends and the daemons, and we ended up replacing that with one written in Scala. The Ruby one actually worked pretty decently in a normal steady state, but the startup time and the crash behavior were undesirable.
- ^ "Twitter jilts Ruby for Scala". theregister.co.uk. 1 April 2009. Archived from the original on 12 August 2017. Retrieved 18 July 2009.
By the end of this year, Payne said, Twitter hopes to have its entire middleware infrastructure and its APIs ported to the new language. Ruby will remain, but only on the front end. "We're still happy with Rails for building user facing features... performance-wise, it's fine for people clicking around web pages. It's the heavy lifting, asynchronous processing type of stuff that we've moved away from."
- ^ Ryan King (25 September 2009). "Twitter on Ruby". Evan Weaver. Archived from the original on 27 September 2009. Retrieved 29 September 2009.
We use Scala for a few things at Twitter, but the majority of the site is Ruby.
- ^ "Twitter Search is Now 3x Faster". Twitter. Retrieved 6 June 2014.
- ^ "I won't let you pay me for my open source". Archived from the original on 15 December 2021. Retrieved 15 December 2021.
- ^ "Why we're sticking with Ruby on Rails". GitLab. Archived from the original on 29 August 2022. Retrieved 29 August 2022.
- ^ "Here's Why Ruby On Rails Is Hot". Business Insider. Archived from the original on 21 December 2011. Retrieved 10 February 2012.
- ^ "Ruby on Rails Usage Statistics". trends.builtwith.com. Archived from the original on 12 February 2012. Retrieved 4 January 2016.
- ^ "Ruby on Rails Token Usage Statistics". trends.builtwith.com. Archived from the original on 14 March 2016. Retrieved 4 January 2016.
- ^ Protalinski, Emil. "How GitHub handled getting hacked". Zdnet.com. Retrieved 24 May 2017.
- ^ Brook, Chris (25 September 2013). "Security Issue in Ruby on Rails Could Expose Cookies". Threat Post. The Kaspersky Lab Security News Service. Retrieved 4 June 2014.
- ^ "Patching up Web applications". MIT News. 15 April 2016. Archived from the original on 27 July 2019. Retrieved 21 April 2016.
Bibliography
- Ruby, Sam; Thomas, Dave; Hansson, David (28 March 2009). Agile Web Development with Rails (Third ed.). ISBN 978-1-934356-16-6.
- Laurent, Simon St.; Dumbill, Edd (28 November 2008). Learning Rails (First ed.). ISBN 978-0-596-51877-6.
- Lenz, Patrick (1 May 2008). Simply Rails 2 (Second ed.). ISBN 978-0-9804552-0-5.
- Tate, Bruce; Hibbs, Curt (22 August 2006). Ruby on Rails: Up and Running (First ed.). ISBN 0-596-10132-5. Archivedfrom the original on 27 June 2009. Retrieved 12 July 2009.
- Holzner, Steve (29 November 2006). Beginning Ruby on Rails (First ed.). ISBN 0-470-06915-5. Archived from the originalon 23 April 2012. Retrieved 12 July 2009.
- Allan Hardy, Jeffrey; Carneiro Jr, Cloves; Catlin, Hampton (20 July 2007). Beginning Ruby on Rails E-Commerce: From Novice to Professional (First ed.). ISBN 978-1-59059-686-9. Archived from the originalon 17 September 2010. Retrieved 12 July 2009.
- Clark, Mike (15 May 2008). Advanced Rails Recipes (First ed.). Pragmatic Bookshelf. p. 464. ISBN 978-0-9787392-2-5.