The front controller
software design pattern is listed in several pattern catalogs and is related to the design of web applications. It is "a
controller that handles all requests for a
website,"
which is a useful structure for web application developers to achieve flexibility and reuse without code redundancy.
Instruction

Front controllers are often used in
web applications to implement workflows. While not strictly required, it is much easier to control navigation across a set of related pages (for instance, multiple pages used in an online purchase) from a front controller than it is to assign individual pages responsibility for navigation.
The front controller may be implemented as a
Java object, or as a script in a
scripting language
A scripting language or script language is a programming language that is used to manipulate, customize, and automate the facilities of an existing system. Scripting languages are usually interpreted at runtime rather than compiled.
A scripti ...
such as
PHP
PHP is a General-purpose programming language, general-purpose scripting language geared toward web development. It was originally created by Danish-Canadian programmer Rasmus Lerdorf in 1993 and released in 1995. The PHP reference implementati ...
,
Raku,
Python or
Ruby
A ruby is a pinkish red to blood-red colored gemstone, a variety of the mineral corundum (aluminium oxide). Ruby is one of the most popular traditional jewelry gems and is very durable. Other varieties of gem-quality corundum are called sapp ...
that is called for every request of a web
session. This script would handle all tasks that are common to the application or the framework, such as session handling,
caching
In computing, a cache ( ) is a hardware or software component that stores data so that future requests for that data can be served faster; the data stored in a cache might be the result of an earlier computation or a copy of data stored elsewher ...
and input filtering. Based on the specific request, it would then instantiate further objects and call methods to handle the required tasks.
The alternative to a front controller is the usage of page controllers mapped to each site page or path. Although this may cause each individual controller to contain duplicate code, the page-controller approach delivers a high degree of specialization.
Examples
Several web-tier application frameworks implement the front controller pattern:
*
Apache Struts
*
ASP.NET MVC
*
Cairngorm framework in
Adobe Flex
* Cro or Bailador frameworks in
Raku
*
Drupal
*
MVC frameworks written in
PHP
PHP is a General-purpose programming language, general-purpose scripting language geared toward web development. It was originally created by Danish-Canadian programmer Rasmus Lerdorf in 1993 and released in 1995. The PHP reference implementati ...
, such as
Yii,
CakePHP,
Laravel,
Symfony,
CodeIgniter and
Laminas
*
Spring Framework
*
Yesod, written in
Haskell
Implementation
Front controllers may divided into three components:
#
XML
Extensible Markup Language (XML) is a markup language and file format for storing, transmitting, and reconstructing arbitrary data. It defines a set of rules for encoding documents in a format that is both human-readable and machine-readable. ...
mapping: files that map requests to the class that will handle the request processing.
# Request processor: used for request processing and modifying or retrieving the appropriate model.
# Flow manager: determines what will be shown on the next page.
Participants and responsibilities
Java implementation example
The front controller implemented in Java code:
private void doProcess(HttpServletRequest request,
HttpServletResponse response)
throws IOException, ServletException {
...
try {
getRequestProcessor().processRequest(request);
getScreenFlowManager().forwardToNextScreen(request, response);
} catch (Throwable ex) {
String className = ex.getClass().getName();
nextScreen = getScreenFlowManager().getExceptionScreen(ex);
// Put the exception in the request
request.setAttribute("javax.servlet.jsp.jspException", ex);
if (nextScreen null) {
// Send to general error screen
ex.printStackTrace();
throw new ServletException("MainServlet: unknown exception: " +
className);
}
}
Benefits and liabilities
There are three primary benefits associated with the front controller pattern.
* Centralized control. The front controller handles all the requests to the
web application. This implementation of centralized control that avoids using multiple controllers is desirable for enforcing application-wide policies such as user tracking and security.
* Thread safety. A new command object arises when receiving a new request, and the command objects are not meant to be thread-safe. Thus, it will be safe in the command classes. Though safety is not guaranteed when threading issues are gathered, code that interacts with commands is still thread-safe.
* Configurability. As only one front controller is employed in a web application, the application configuration may be greatly simplified. Because the handler shares the responsibility of dispatching, new commands may be added without changes needed to the code.
The front controller pattern may incur performance issues because the single controller is performing a great deal of work, and handlers may introduce bottlenecks if they involve database or document queries. The front controller approach is also more complex than that of page controllers.
Relationship with MVC
# In order to improve system reliability and maintainability, duplicate code should be avoided and centralized when it involves common logic used throughout the system.
# The data for the application is best handled in a single location, obviating the need for duplicate data-retrieval code.
# Different roles in the
model-view-controller (MVC) pattern should be separated to increase testability, which is also true for the controller part in the MVC pattern.
Comparison
The page-controller pattern is an alternative to the front controller approach in the MVC model.
{, class="wikitable"
!
!Page Controller
!Front Controller
, -
, Base class
, A base class is needed and will grow simultaneously with the development of the application.
, The centralization of requests is easier to modify than is a base class.
, -
, Security
, Low security because various objects react differently without consistency.
, High, because the controller is implemented in a coordinated fashion.
, -
, Logical Page
, Single object on each logical page.
, Only one controller handles all requests.
, -
, Complexity
, Low
, High
See also
*
Design pattern (computer science).
*
Mediator pattern (note: the front controller pattern is a specialized kind of mediator pattern)
References
Notes
*
*
External links
Bear Bibeault's Front Man™ a lightweight Java implementation.
{{Design Patterns patterns
Architectural pattern (computer science)
Software design patterns