Grails (framework)
Developer(s) | Graeme Rocher |
---|---|
Initial release | October, 2005 |
Stable release | 3.1.4 / March 16, 2016 |
Written in | Groovy |
Operating system | Cross-platform |
Platform | Cross-platform (JVM) |
Type | Web application framework |
License | Apache License 2.0 |
Website |
grails |
Grails is an open source web application framework that uses the Groovy programming language (which is in turn based on the Java platform). It is intended to be a high-productivity framework by following the "coding by convention" paradigm, providing a stand-alone development environment and hiding much of the configuration detail from the developer.
Grails was previously known as 'Groovy on Rails'; in March 2006 that name was dropped in response to a request by David Heinemeier Hansson, founder of the Ruby on Rails framework.[1] Work began in July 2005, with the 0.1 release on March 29, 2006 and the 1.0 release announced on February 18, 2008.
G2One - The Groovy Grails Company - was acquired by SpringSource in November, 2008,[2] and it was later acquired by VMware.[3]
On April 9, 2015, OCI (Object Computing, Inc.) announced that Graeme Rocher, Grails Co-Founder and Project Lead, and Jeff Brown, Principal Software Engineer and Senior member of Grails Core Team, have joined OCI to lead its Grails product team. OCI is now the official sponsor and has taken over funding for the Grails project.[4] The Grails core team retains full autonomy as to how the project will be developed and advanced.[5] Moving forward, OCI is committed to increasing the exposure of Grails, and working to integrate Grails technology with other open source infrastructure technologies that OCI supports.
Overview
Grails was developed to address a number of goals:
- Provide a web framework for the Java platform.
- Re-use existing Java technologies such as Hibernate and Spring under a single interface
- Offer a consistent development framework.
- Offer documentation for key portions of the framework:
- The Persistence framework.
- Templates using GSP (Groovy Server Pages).
- Dynamic tag libraries for creating web page components.
- Customizable and extensible Ajax support.
- Provide sample applications that demonstrate the framework.
- Provide a complete development mode,[6] including a web server and automatic reload of resources.
High productivity
Grails has three properties that differentiate it from traditional Java web frameworks:
No XML configuration
Creating web applications in Java traditionally involves configuring environments and frameworks at the start and during development. This configuration is very often externalized in XML files to ease configuration and avoid embedding configuration in application code.
XML was initially welcomed as it provided greater consistency to configure applications. However, in recent years, it has become apparent that although XML is great for configuration, it can be tedious to set up an environment. This may reduce productivity as developers spend time understanding and maintaining framework configuration as the application grows. Adding or changing functionality in applications that use XML configuration adds an extra step to the change process, which slows down productivity and may diminish the agility of the entire process.
Grails removes the need to add configuration in XML files. Instead, the framework uses a set of rules or conventions while inspecting the code of Grails-based applications. For example, a class name that ends with Controller
(for example BookController
) is considered a web controller.
Ready-to-use development environment
When using traditional Java web toolkits, it's up to developers to assemble development units, which can be tedious. Grails provides a development environment that includes a web server to get developers started right away. All required libraries are part of the Grails distribution and Grails prepares the Java web environment for deployment automatically.
Functionality available through mixins
Grails features dynamic methods on several classes through mixins. A mixin is a method that is added to a class dynamically, as if the functionality had been compiled into the program.
These dynamic methods allow developers to perform operations without having to implement interfaces or extend base classes. Grails provides dynamic methods based on the type of class. For example, domain classes have methods to automate persistence operations like save, delete and find.
Web framework
The Grails web framework has been designed according to the MVC paradigm.
Controllers
Grails uses controllers to implement the behavior of web pages. Below is an example of a controller:
class BookController {
def list() {
[ books: Book.list() ]
}
}
The controller above has a list
action which returns a model containing all books in the database. To create this controller the grails
command is used, as shown below:
grails create-controller Book
This command creates a class in the grails-app/controller
directory of the Grails project. Creating the controller class is sufficient to have it recognized by Grails. The list
action maps to http://localhost:8080/book/list
in development mode.
Views
Grails supports JSP and GSP. The example below shows a view written in GSP which lists the books in the model prepared by the controller above:
<html>
<head>
<title>Our books</title>
</head>
<body>
<ul>
<g:each in="${books}">
<li>${it.title} (${it.author.name})</li>
</g:each>
</ul>
</body>
</html>
This view should be saved as grails-app/views/book/list.gsp
of the Grails project. This location maps to the BookController
and list
action. Placing the file in this location is sufficient to have it recognized by Grails.
There is also a GSP tag reference available.
Dynamic tag libraries
Grails provides a large number of tag libraries out of the box. However you can also create and reuse your own tag libraries easily:[7]
class ApplicationTagLib {
def formatDate = { attrs, body ->
out << new java.text.SimpleDateFormat(attrs.format).format(attrs.date)
}
}
The formatDate
tag library above formats a java.util.Date
object to a String
. This tag library should be added to the grails-app/taglib/ApplicationTagLib.groovy
file or a file ending with TagLib.groovy
in the grails-app/taglib
directory.
Below is a snippet from a GSP file which uses the formatDate
tag library:
<g:formatDate format="yyyyMMdd" date="${myDate}"/>
To use a dynamic tag library in a GSP no import tags have to be used. Dynamic tag libraries can also be used in JSP files although this requires a little more work.
Persistence
Model
The domain model in Grails is persisted to the database using GORM (Grails Object Relational Mapping). Domain classes are saved in the grails-app/domain
directory and can be created using the grails
command as shown below:
grails create-domain-class Book
This command requests the domain class name and creates the appropriate file. Below the code of the Book
class is shown:
class Book {
String title
Person author
}
Creating this class is all that is required to have it managed for persistence by Grails. With Grails 0.3, GORM has been improved and e.g. adds the properties id and version itself to the domain class if they are not present. The id property is used as the primary key of the corresponding table. The version property is used for optimistic locking.
Methods
When a class is defined as a domain class, that is, one managed by GORM, methods are dynamically added to aid in persisting the class's instances.
Dynamic Instance Methods
The save()
method saves an object to the database:
def book = new Book(title:"The Da Vinci Code", author:Author.findByName("Dan Brown"))
book.save()
The delete()
method deletes an object from the database:
def book = Book.findByTitle("The Da Vinci Code")
book.delete()
The refresh()
method refreshes the state of an object from the database:
def book = Book.findByTitle("The Da Vinci Code")
book.refresh()
The ident()
method retrieves the object's identity assigned from the database:
def book = Book.findByTitle("The Da Vinci Code")
def id = book.ident()
Dynamic Static (Class) methods
The count()
method returns the number of records in the database for a given class:
def bookCount = Book.count()
The exists()
method returns true if an object exists in the database with a given identifier:
def bookExists = Book.exists(1)
The find()
method returns the first object from the database based on an object query statement:
def book = Book.find("from Book b where b.title = ?", [ 'The Da Vinci Code' ])
Note that the query syntax is Hibernate HQL.
The findAll()
method returns all objects existing in the database:
def books = Book.findAll()
The findAll()
method can also take an object query statement for returning a list of objects:
def books = Book.findAll("from Book")
The findBy*()
methods return the first object from the database which matches a specific pattern:
def book = Book.findByTitle("The Da Vinci Code")
Also:
def book = Book.findByTitleLike("%Da Vinci%")
The findAllBy*()
methods return a list of objects from the database which match a specific pattern:
def books = Book.findAllByTitleLike("The%")
The findWhere*()
methods return the first object from the database which matches a set of named parameters:
def book = Book.findWhere(title:"The Da Vinci Code")
Scaffolding
Grails supports scaffolding to support CRUD operations (Create, Read, Update, Delete). Any domain class can be scaffolded by creating a scaffolding controller as shown below:
class BookController {
static scaffold = true
}
By creating this class you can perform CRUD operations on http://localhost:8080/book
. This works because the BookController follows the same naming convention as the Book domain class. To scaffold a specific domain class we could reference the class directly in the scaffold property:
class SomeController {
static scaffold = Book
}
Currently Grails does not provide scaffolding for associations.
Legacy Database Models
The persistence mechanism in GORM is implemented via Hibernate. As such, legacy databases may be mapped to GORM classes using standard Hibernate mapping files.
Creating a Grails project
Download and installation guidelines for Grails are available on the Grails web site.[8]
Grails provides support scripts to create and execute projects as follows:
- Grails will create a complete outline application in response to the command
grails create-app <application-name>
This command will request the name of the project and creates a project directory with the same name. Further grails
commands can be issued in this directory to create the classes and web pages of the application.
The command grails run-app
will run the application on a built-in web server. The application can be accessed at the URL http://localhost:8080/<context-name>
. By default, the context name is the same as the application name used when the project was created.
Target audience
The target audience for Grails is:
- Java or Groovy developers who are looking for an integrated development environment to create web-based applications.
- Developers without Java experience looking for a high-productivity environment to build web-based applications.
Integration with the Java platform
Grails is built on top of and is part of the Java platform meaning that it is very easy to integrate with Java libraries, frameworks and existing code bases. Grails offers transparent integration of classes which are mapped with the Hibernate ORM framework. This means existing applications which use Hibernate can use Grails without recompiling the code or reconfiguring the Hibernate classes while using the dynamic persistence methods discussed above.
One consequence of this is that scaffolding can be configured for Java classes mapped with Hibernate. Another consequence is that the capabilities of the Grails web framework are fully available for these classes and the applications which use them.
Grails also makes use of the Spring Inversion of Control Framework; Grails is actually a Spring MVC application under the hood.[9] The Spring framework can be used to provision additional Spring beans and introduce them into the context of the application. The SiteMesh framework is used to manage the presentation layer, simplifying the development of pages via a robust templating system.[10]
Grails applications are packaged as war artifacts that can be deployed to any servlet container or Java EE application servers.
See also
- Groovy (programming language)
- JRuby
- Griffon (framework) - A Desktop framework inspired by Grails
- Play Framework
- Spring Roo
- Comparison of web frameworks
References
- ↑ Dropping Groovy on Rails name
- ↑ Delap, Scott. "SpringSource Embraces Groovy and Grails with Acquisition of G2One". InfoQ.com. Retrieved 2008-11-11.
- ↑ http://colinharrington.net/blog/2009/08/vmware-acquiring-springsource-which-acquired-g2one/
- ↑ http://interact.stltoday.com/pr/business/PR040915114421060
- ↑ http://www.infoworld.com/article/2615156/application-development/groovy--the-road-map-for-the-popular-jvm-language.html
- ↑ Why use Grails
- ↑ 7.3 Tag Libraries
- ↑ Grails Installation Steps
- ↑ "Grails Documentation".
- ↑ "Slideshare Presentation".
- Brown, Jeff; Rocher, Graeme (January 15, 2009), The Definitive Guide to Grails (2nd ed.), Apress, p. 648, ISBN 1-59059-995-0
- Smith, Glen; Ledbrook, Peter (June 28, 2009), Grails in Action (1st ed.), Manning Publications, p. 520, ISBN 1-933988-93-2
- Abdul-Jawad, Bashar (December 2, 2008), Groovy and Grails Recipes (1st ed.), Apress, p. 424, ISBN 978-1-4302-1600-1
- Fischer, Robert (April 20, 2009), Grails Persistence with GORM and GSQL (1st ed.), Apress, p. 125, ISBN 1-4302-1926-2
- M. Judd, Christopher; Nusairat, Joseph Faisal; Shingler, Jim (June 18, 2008), Beginning Groovy and Grails: From Novice to Professional (1st ed.), Apress, p. 440, ISBN 1-4302-1045-1
- Rudolph, Jason (February 6, 2007), Getting Started with Grails (1st ed.), Lulu.com, p. 132, ISBN 1-4303-0782-X
External links
- The Grails home page
- The Groovy home page
- Beginner Tutorial an series of tutorial for learning the Grails framework
- Mastering Grails An 18-part on-line tutorial provided by IBM (from 2008)