This section contains the release notes for the Version 1.1 build of the Struts Framework, for changes that have taken place since Version 1.1 Release Candidate 2 was issued. For a complete list of changes since the last production release, see the Introduction
In RC2, the Commons-DBCP and Commons-Pool dependencies have been removed . These are replaced with a dependency on the Struts-Legacy package , containing the GenericDataSource and GenericConnection classes from Struts 1.0.2. These are distributed for J2SE 1.3 but may be recompiled for J2SE 1.4. Other DataSource implementations may be plugged in (recommended).
Other changes since RC1 have been routine fixes and refactorings.
OTHER CHANGES:
Action package: Deprecated processActionForward() because ActionForward is a subclass of ForwardConfig so there's no reason we can't use processForwardConfig() instead. Updated to use processForwardConfig instead of deprecated processActionForward. Deprecated the rest of the Action constants in favor of Globals. Refactored some of initModuleConfig into a separate method and cleaned up. Improved exception handling in ActionServlet and RequestProcessor; generally, we limited the scope of try/catch blocks and caught specific exceptions rather than Throwable.
Documentation: Document the <html:html> tag's locale attribute behaviour of creating a session if needed. Added note to validator section regarding the converNull servlet parameter and required validations of java.lang.Integer fields. Moved sites and consultants page to Struts Wiki. Other minor tweaks.
EL package: Fixed mapping of "onkeypress" attribute. Separated "expr" attribute into "expr" and "exprValue", being the original attribute value and the evaluated value. Fixed probably long-standing bug in notMatch tag that made it behave identically to the "match" tag (instead of the reverse).
Example applicattions: Added Multi-config files for the example app.
Legacy package: Added package under contrib to host old GenericDataSource and GenericConnection classes.
Taglibs packages: Fixed several import statements. Refactored converting a scope name into its integer constant into a new method RequestUtils.getScope(String), and changed the DefineTag, EmptyTag, and TagUtils classes to use the new method.
faces taglib. Added early release to contrib area.
html taglib. Reset the 'processed' flag at the beginning of each usage of the tag. Use a local copy of the 'name' attribute to avoid modifying the attribute value itself. Fixed references to static members. For FrameTag and HiddenTag, conform TLD with implementations. In ErrorsTag, render a platform-independent line ending instead of hard coded "\r\n". In JavaScriptValidatorTag, make the line-end generation platform independent so that Cactus tests work properly. In FormTag, refactored code into smaller reusable methods. In RewriteTag, encode the ampersand character in XHTML mode only, otherwise write the ampersand as is so the URL will work in JavaScript scripts. Refactored form bean initialization out of doStartTag() into its own method. Refactored doStartTag() 'if' statement to avoid having long nested 'if' logic. In ErrorTag, fixed formatting and deprecated unused defaultLocale variable. Refactored doStartTag() and doEndTag() into smaller methods. Moved xhtml check to RequestUtils instead of duplicating the logic in many different classes. Added lookupProperty() method to BaseHandlerTag because both RadioTag and TextareaTag used the same code. Refactored TextareaTag into smaller methods. In JavaScriptValidatorTag, replaced duplicated code with call to RequestUtils.retrieveUserLocale() and simplified an 'if' statement.
logic taglib. Set 'iterator' to null in doEndTag() so that we release the iterator reference as early as possible. We cannot do the same for 'collection' since it is a tag attribute, and needs to remain unchanged to comply with the JSP spec. Don't create empty cookies array if null, just don't run the loop at all. In ForwardTag, remove unnecessary test for null.
nested tablibs. Improved support for Tomcat 4.1.18. Replace EVAL_BODY_AGAIN with EVAL_BODY_TAG so that the code compiles against the JSP 1.1 API. Changed the <nested:define> tag's tei class to reference a new custom tei class for the nested tags.
tiles taglib. Fixed references to static members. Deprecated outdated Tiles TextTag. For InsertTag, only include page if it's non-null. For InserTag, remove page check before including for more investigation.
Test packages: Added several new tests for the bean, html, and logic taglibs to the suite setup at the tail-end of RC1. Note: We cannot resolve request.getServerPort() in the Cactus 1.4.x environment, so for now, our tests will only run on Cactus 1.3
Tiles package: Deprecated TilesUtil.applicationClass() in favor of RequestUtils.applicationClass()
Util package: retrieveUserLocale now uses the request.getLocale() method for finding the user's preferred locale. If user has not specified this with Accept-Language header, the server default locale is used. Change encodeURL() to not use reflection on every call. In RequestUtils, simplified separator logic in computeURL().
Validator package: Deprecate logging methods and indicate that commons-logging should be used. Logic simplification and minor formatting fixes to Resources class.
build files:
Bugzilla Problem Report fixes:
The remainder of this document contains the release notes for 1.1 Release Candidate 2 build of the Struts Framework, and covers changes that have taken place since Version 1.0.2 was released. The following sections cover New Features and Changes to Struts.
The binary distribution of this release includes the following files relevant to Struts:
INSTALL
                        - Brief installation instructions. See
                        the
                        Struts Documentation Application
                        , or online at
                        
                            http://jakarta.apache.org/struts/
                        ,
                        for more information.
                    LICENSE
                        - The Apache Software Foundation license that
                        defines the terms under which you can use Struts (and
                        other software
                        licensed by Apache).
                    README
                        - A brief introduction to Struts.
                    lib/
                        - Directory containing files you will need in
                        your own applications. The individual files of
                        interest are:
                        commons-*.jar
                                - Release packages from the
                                
                                    Jakarta Commons
                                    Project
                                that Struts relies on. You are welcome to use
                                these
                                classes in your own applications. These JAR
                                files should be
                                copied into the
                                /WEB-INF/lib
                                directory of
                                your web application. See below for the
                                version of each
                                Commons library that is included.
                            struts.jar
                                - JAR file that contains the compiled
                                Java classes of Struts. You must
                                place this file in the
                                /WEB-INF/lib
                                directory of
                                your web application.
                            struts-xxxxx.tld
                                - The tag library descriptor files
                                for the Struts 1.1 tag libraries (bean, html,
                                logic, and
                                template). You must place these files in the
                                /WEB-INF
                                directory of your web application, and
                                reference them with
                                appropriate
                                <taglib>
                                directives in your
                                web.xml file.
                            jdbc2_0-stdext.jar
                                - The JDBC 2.0 Optional Package
                                API classes (package
                                javax.sql
                                ). You will need to
                                include this file in the
                                /WEB-INF/lib
                                directory
                                of your application, if it is not already made
                                visible to web
                                applications by your servlet container.
                            struts-config_1_1.dtd
                                - The Document Type Definition
                                (DTD) for the Struts 1.1 configuration file
                                (which is typically named
                                /WEB-INF/struts-config.xml
                                ). Your configuration file
                                will be validated against an internal copy of
                                this DTD -- this
                                copy is available for reference purposes only.
                            struts-config_1_0.dtd
                                - The Document Type Definition
                                (DTD) for the Struts 1.0 configuration file
                                (which is typically named
                                /WEB-INF/struts-config.xml
                                ). Your configuration file
                                will be validated against an internal copy of
                                this DTD -- this
                                copy is available for reference purposes only.
                            web-app_2_2.dtd
                                - The Document Type Definition (DTD)
                                for web.xml files conforming to the Servlet
                                2.2 specification.
                                This copy is for reference purposes only.
                            web-app_2_3.dtd
                                - The Document Type Definition (DTD)
                                for web.xml files conforming to the Servlet
                                2.3 specification.
                                This copy is for reference purposes only.
                            webapps/
                        - Web Application Archive (WAR) files for the
                        web applications that are included with Struts.
                    The following Jakarta Commons libraries are included with this release of Struts:
Following are highlights of the new features. In the next section, we provide links to the JavaDocs for the affected classes.
New Configuration DTD
The Struts Configuration 1.0 DTD has been deprecated in
                    favor of the
                    
                            struts-config_1_1.dtd
                    .
                    In the Struts 1.1 release, existing Struts configuration
                    files can be
                    loaded using either DTD version.
                
New Dependencies on Commons packages
Several components of Struts 1.0 have been found to be
                    useful in
                    general Java development (and not just useful for building
                    Struts-based
                    web applications), and have been migrated into the
                    Jakarta
                        Commons Project
                    .
                    As a result, this release of Struts has been modified
                    to rely on the Commons packages containing these classes,
                    rather than the
                    Struts internal versions. In nearly every case, this
                    involved changing
                    only the
                    import
                    statements at the top of the classes. Any
                    of your applications that utilize these classes will need
                    to be modified in
                    the same way.
                
The following Commons packages contain the replacements for the corresponding Struts 1.0 classes:
org.apache.commons.beanutils
                        ] -
                        org.apache.struts.utils.BeanUtils
                        ,
                        org.apache.struts.utils.ConvertUtils
                        , and
                        org.apache.struts.utils.PropertyUtils
                        .
                    org.apache.commons.collections
                        ] -
                        org.apache.struts.util.ArrayStack
                        ,
                        org.apache.struts.util.FastArrayList
                        ,
                        org.apache.struts.util.FastHashMap
                        ,
                        org.apache.struts.util.FastTreeMap
                        .
                    org.apache.commons.digester
                        ] -
                        org.apache.struts.digester.*
                        .
                    The following Commons packages are also now used by various components of the Struts framework:
org.apache.commons.fileupload
                        ]
                    org.apache.commons.logging
                        ]
                    org.apache.commons.validator
                        ]
                    NOTE! XML Parser Prerequisite Updated
Struts now depends on an XML parser that conforms to the JAXP/1.1 (rather than JAXP/1.0) APIs. Parsers known to work include the JAXP/1.1 reference implementation, and Xerces 1.3.1.
SOURCE DEVELOPERS NOTE! Ant Prerequisite Updated
To build Struts from source Ant 1.4 or later is now required. This does not affect developers that use Struts from the binary distribution.
Struts Validator Integration
The new Commons Validator is now integrated with Struts and exposed through the new Validator package.
Tiles - An advanced templating taglib
The Tiles JSP assembly framework has been integrated with Struts.
Nested - An very cool taglib extension
The Nested taglib is bundled with Struts and enhances the functionality of the existing Struts tags.
New Example Applications
New example applications for the Validator and Tiles are now part of the Struts distribution.
New Contrib directory for optional components
A new directory (
                    contrib
                    ) in the CVS source repository has
                    been added to accumulate Struts add-on extensions that are
                    generally
                    useful but have not yet been integrated into the standard
                    code base.
                
The source for these components is available in the Struts source distribution. Binary distributions may also be made available in the Struts download area. As optional components, these products have their own release cycles.
Action Package Additions
The following new features have been added to the basic
                    controller
                    framework [
                    org.apache.struts.action
                    ]:
                
ActionMessages
                        class will support a superset of
                        the capabilities of
                        ActionErrors
                        , and will be useful as
                        a collection of general purpose messages, not just
                        errors.
                    Upload Package Additions
The following new features have been added to the file
                    upload classes
                    [
                    org.apache.struts.upload
                    ]:
                
CommonsMultipartRequestHandler:
                        New class that implements
                        file upload using the Jakarta Commons FileUpload
                        package. This is now
                        the default file upload implementation for Struts.
                    Util Package Additions
The following new features have been added to the utility
                    classes
                    [
                    org.apache.struts.util
                    ]:
                
LocalStrings:
                        Correct message regarding replaceable parameter so
                        that it does not append an extraneous character.
                    LabelValueBean:
                        New class that defines a collection of name/value
                        pairs that can be used with the <html:options>
                        and <html:optionsCollection> tags, and
                        elsewhere.
                    MessageResources:
                        Escape any single quote characters that are included
                        in the specified message string.
                    computeParameters:
                        Allow a transaction token to be the only parameter.
                    RequestUtils:
                        Change to encode ampersands when building a query
                        string.
                    Bean Taglib Package Additions
The following new features have been added to the
                    struts-bean
                    custom tag library
                    [
                    org.apache.struts.taglib.bean
                    ]:
                
<bean:write>
                        : Add format, locale and bundle attributes to support
                        formatting values according to current
                        user locale, format string from attribute or format
                        string from string resources.
                    <bean:cookie>, <bean:header>, or <bean:parameter>:
                        Correct the generated scripting variable type when tag
                        is used with the "multiple" attribute.
                    <bean:message>:
                        Added
                        name
                        ,
                        property
                        , and
                        scope
                        attributes to the tag, so that the message source key
                        can be obtained dynamically from a bean or bean
                        property.
                    HTML Taglib Package Additions
The following new features have been added to the
                    struts-html
                    custom tag library [
                    org.apache.struts.taglib.html
                    ]:
                
<html:link>:
                        Added 'action' attribute.
                    <html:options>:
                        If the property specified by the 'property' attribute
                        returns null, tag now throws an error message that
                        indicates what the real problem is, rather than
                        causing an NPE.
                    <html:option> and
                            <html:options>:
                        Added 'style' and 'styleClass' attributes.
                    <html:optionsCollection>:
                        New tag providing a cleaner way of populating HTML
                        options from a collection.
                    <bean:message>:
                        Added 'name', 'property' and 'scope' attributes so
                        that the message resource key can be obtained
                        dynamically from a bean.
                    <html:messages>:
                        New tag to iterate through a message collection in the
                        new
                        ActionMessages
                        class.
                    ActionForm:
                        Tag will now call
                        reset()
                        if it instantiates the ActionForm bean. This also
                        requires that the bean instantiated by the tag to be
                        an
                        ActionForm
                        subclass.
                    <html:image>:
                        Added the 'align' attribute.
                    <html:img>:
                        Added the mouse event attributes ('onclick',
                        'ondblclick', 'onmousedown', 'onmouseup',
                        'onmouseover', 'onmousemove', 'onmouseout').
                    SubmitTag, SelectTag, LinkTag.java, CheckboxTag,
                            ButtonTag, ImageTag, RadioTag, and TextArea
                            tags:
                        Added indexed property.
                    Logic Taglib Package Additions
The following new features have been added to the
                    struts-logic
                    custom tag library [
                    org.apache.struts.taglib.logic
                    ]:
                
<logic:empty>
                        and
                        <logic:notEmpty>
                        : New tags that are similar to
                        <logic:present>
                        and
                        <logic:notPresent>
                        except for the treatment of
                        empty strings.
                    Template Taglib Package Additions
The following new features have been added to the
                    struts-template
                    custom tag library
                    [
                    org.apache.struts.taglib.template
                    ]:
                
Documentation Additions
The following new features have been added to the Struts Documentation application (and corresponding contents on the Struts web site):
@since Struts 1.1
                        tag to indicate new packages, classes, and members
                        added after the Struts 1.0.x version
                    Struts Configuration Changes
The following changes and bug fixes have occurred in the configuration files related to Struts:
Added Config Package
Action Package Changes
The following changes and bug fixes have occurred in the
                    basic
                    controller framework (package
                    org.apache.struts.action
                    ):
                
Upload Package Changes
The following changes and bug fixes have occurred in the
                    file upload
                    package (package
                    org.apache.struts.upload
                    ) [part of the Upload webapp]:
                
Utility Package Changes
The following changes and bug fixes have occurred in the
                    utilities
                    (package
                    org.apache.struts.util
                    ):
                
org.apache.commons.dbpc.BasicDataSource
                        ].
                        Replaced by direct use of BasicDataSource or other
                        compatible component.
                    Bean Taglib Package Changes
The following changes and bug fixes have occurred in the
                    struts-bean
                    custom tag library
                    [
                    org.apache.struts.taglib.bean
                    ]:
                
HTML Taglib Package Changes
The following changes and bug fixes have occurred in the
                    struts-html
                    custom tag library (package
                    org.apache.struts.taglib.html
                    ):
                
Logic Taglib Package Changes
The following changes and bug fixes have occurred in the
                    struts-logic
                    custom tag library (package
                    org.apache.struts.taglib.logic
                    ):
                
Documentation Application Changes
The following changes and bug fixes to the Struts Documentation application (and corresponding contents on the Struts web site) have occurred:
MailReader Example Application Changes
The following changes and bug fixes to the Struts MailReader Example Application have occurred:
Template Example Application Changes
The following changes and bug fixes to the Struts Template Example Application have occurred:
Exercise Taglib Example Application Changes
The following changes and bug fixes to the Struts Exercise Taglib Example Application have occurred:
This section provides links to the Struts JavaDoc for any classes that have been added or deprecated since the Struts 1.0 release.
Previously deprecated classes and packages removed in Struts 1.1
org.apache.struts.utils.BeanUtils
                        ,
                        org.apache.struts.utils.ConvertUtils
                        , and
                        org.apache.struts.utils.PropertyUtils
                        - replaced by
                        org.apache.commons.beanutilsorg.apache.struts.util.ArrayStack
                        ,
                        org.apache.struts.util.FastArrayList
                        ,
                        org.apache.struts.util.FastHashMap
                        ,
                        org.apache.struts.util.FastTreeMap
                        - replaced by
                        org.apache.commons.collectionsorg.apache.struts.digester.*
                        - replaced by
                        org.apache.commons.digesterstruts-config.dtd
                        - Replaced by
                        struts-config_1_1.dtd
                        .
                    Packages added in Struts 1.1
Classes added in Struts 1.1
action
actions
taglib.html
taglib.logic
upload
util
Classes with members added in Struts 1.1
Classes deprecated between Struts 1.0 and Struts 1.1
action
Classes with members deprecated between Struts 1.0 and Struts 1.1
Next: Installation