Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 178 Next »

Welcome to Apache Struts 2

Apache Struts 2 is a flexible control layer based on standard technologies like Java Filters, JavaBeans, ResourceBundles, Locales, and XML, as well as various OpenSymphony packages, like OGNL and XWork. The framework helps you create an extensible development environment for your application, based on industry standards and proven design patterns.

Work in progress!

Apache Struts 2 is at a pre-release, pre-Alpha stage. If you are just getting started with Struts2/WebWork2, we recommend WebWork 2.2 as an entry point. WW2 is stable and production ready. When Struts 2 is released, migration paths for WebWork 2 and Struts 1 developers will be available.

See the Struts 2 release plan for details and status.

Apache Struts 2 in a Nutshell

The framework provides its own web Controller component and integrates with other technologies to provide the Model and the View. For the Model, the framework can interact with standard data access technologies, like JDBC and EJB, as well as most any third-party packages, like Cayenne, Hibernate, or iBATIS. For the View, the framework works well with JavaServer Pages, including JSTL and JSF, as well as FreeMarker or Velocity Templates, PDF, XSLT, and other presentation systems.

The framework's Controller acts as a bridge between the application's Model and the web View. When a request is received, the Controller invokes an Action class. The Action class consults with the Model (or, preferably, a Facade representing your Model) to examine or update the application's state. To transfer data between the Model and the View, properties can be placed on the Action class, or on a plain old JavaBean.

Most often, the Model is represented as a graph of JavaBean objects. Preferably, the Model will do the "heavy lifting", and the Action will act as a "traffic cop" or adapter. The framework provides sophisticated, automatic type conversion to simplify transfering data between rich domain objects and text-only HTTP requests.

To make it easier to access dynamic data obtained by an Action, the framework includes a library of custom tags. The tags interact with the framework's validation and internationalization features, to ensure that input is correct and output is localized. The tag library can be used with JSP, FreeMarker, or Velocity.

Struts Configuration in a Nutshell

A web application uses a deployment descriptor to initialize resources like servlets and taglibs. The deployment descriptor is formatted as a XML document and named web.xml. Likewise, the framework uses a configuration file, named struts.xml, to initialize its own resources. These resources include action mappings, to direct input to server-side Action classes, and result types, to select output pages.

Here's a simple configuration (struts.xml) for a login workflow:

<struts>
    <include file="struts-default.xml"/>

    <package name="default" namespace="/" extends="struts-default">

        <action name="Logon" class="mailreader2.Logon">
            <result name="input">/pages/Logon.jsp</result>
            <result name="cancel" type="redirect-action">Welcome</result>
            <result type="redirect-action">MainMenu</result>
            <result name="expired" type="chain">ChangePassword</result>
        </action>

        <action name="Logoff" class="mailreader2.Logoff">
            <result type="redirect-action">Welcome</result>
        </action>

    </package>
</struts>

Aside from actions and results, you can also specify exception handlers and interceptors. Interceptors specify the "request-processing lifecycle" for an action. (What happens to the request before and after the Action class fires.) You can specify both global and local lifecycles. If some of your actions respond to AJAX, SOAP, or JSF requests, you can simplify the lifecycle, and even just "pass through" the request, if you like.

Struts 2 is extensible. Very extensible. Every class deployed by the framework is based on an interface. We provide base classes, but you can substitute your own. In the case of Action classes, even the interface is optional. POJO web development is here!

The framework provides general-purpose defaults, and you can start using Struts 2 "out of the box". But you can override any of the defaults in your application's configuration. We provide the base framework, but you can still write your application your way.

Getting Started

The documentation is grouped into three areas.

Tutorials

Our tutorials are designed to get started with the framework soon as possible. We offer an all-purpose "soup to nuts" tutorial as well as specialty tutorials on portlets and database access.

FAQs

Our FAQs provide a wide range of rapid-fire "HOWTOs" in question and answer format.

Guides

Our in-depth guides focus on specific components of the framework, such as Views, the Core framework, and Third-party Extensions.

Tutorials

FAQS

Migrating

General

HOWTO

Configuration

Accessing Resources

Per-Page Settings

Interceptors

Validation

Localization

Type Conversion

Value Stack

Tags

POJOs

Spring

Velocity

Ajax/Dojo

Issues in Specific Environments

Extensions

Portlet Support(JSR168)

Migrating

Guides

Our in-depth guides focus on specific areas of the framework, such as Views, the Core framework, and Third-party Extensions.

We started work on a new User Guide, that should simplify learning process. Please feel free to contribute!

Deprecated Guides

These guides are deprecated and were moved to https://github.com/apache/struts-site

Migration Guide

Getting here from there.

Version Notes 2.5.x

Version Notes 2.3.x

Version Notes 2.2.x

Version Notes 2.1.x

Release Notes 2.0.x

Struts 2.3 to Struts 2.5

Struts 1 to Struts 2

Comparing Struts 1 and 2

How are Struts 1 and Struts 2 alike? How are they different?

Struts 1 Solutions

Various issues (and hopefully their solutions!) encountered during migrations to Struts 2.

Migration Strategies

Steps and overall strategies for migrating Struts 1 applications to Struts 2.

Migration Tools

Development tools to help aid the migration process.

Tutorials

Migrating Applications to Struts 2

A three-part series by Ian Roughley (Sep 2006)

Roadmap

Roadmap FAQ

What's in store for Struts 2?

A History of Struts 2

Don Brown's summary of events

Webwork 2.2 to Struts 2

Key Changes From WebWork 2

What has been removed or changed from WebWork 2.2 to Struts 2

WebWork 2 Migration Strategies

Steps and overall strategies for migrating WebWork 2 applications to Struts 2.

Contributors Guide

Source

Documentation

Core Guide TODOs

  • Creating Resources
  • Writing Validators
  • Writing Type Converters
  • Actions
  • Writing Actions
  • Writing Results

Licensing and Copyright

Errata?

To suggest a change or a correction to any part of the documentation, log in and leave a comment on the appropriate page. We are always looking for help with the documentation!

Next: FAQs

 

  • No labels