+

Search Tips   |   Advanced Search

Changes to configuration files

Struts Portlet Framework-specific init parameters were added so we can customize the Struts application for the portal environment. The portlet and web deployment descriptors require configurations specific to the Struts Portlet Framework. In addition, changes to the Struts configuration file must be made to specify a portal specific request processor as the controller.


Configure the Struts application for the IBM container

Most of the configuration for a Struts application is in the web deployment descriptor file (web.xml). The servlet class specified in the web deployment descriptor must be the portlet servlet. The class name is WpsStrutsPortlet. Here is an example definition.

 <servlet id="Servlet_1">
     <servlet-name>MyStrutsApp</servlet-name>
     <servlet-class>com.ibm.wps.portlets.struts.WpsStrutsPortlet
     </servlet-class>
     ...
 </servlet>

When subclassing WpsStrutsPortlet, we must designate the subclass name for <servlet-name/>. The servlet id must be suffixed with a unique ID to prevent conflicts with other portlets. See Deployment descriptors for more information.

    Initialization parameters
    The following is a list of names of the initialization parameters that can be configured in the web deployment descriptor for Struts portlets with the <init-param> element.

      CommandManagerPlugin
      This configuration parameter allows setting a pluggable CommandManager.

      struts-servlet-mapping
      Identifies a Struts action mapping so that paths that must be treated as Struts actions can be recognized. See Servlet mapping for further details.

      ModuleSearchPath
      Indicates the search path for Struts modules, default value is the markupName and mode. See Using modes for more information.

      IncludesSearchPath
      Indicates a more fine-tuned search path for including a file. If this value is not specified, then PortletContext.include() is used instead.

      NamescopeServletContext
      This allows the WpsStrutsPortlet to be defined in the web deployment descriptor more than once by namescoping the parameters in the servlet context.

      NamescopeFormName
      The default behavior is for the Struts form tag to namescope the name of the portlet. Setting this parameter to false will allow the behavior to be overridden.

      UseGroupsForAccess
      Configures the Struts portlet to use portal server group names as if they were role names. Struts uses roles to determine access to an Action. Set true to configure the Struts application to use the portal's group names as if they were role names to emulate role-based access control.

      UsePortalsLocale
      This parameter allows a Struts application to override default behavior of using the portal's locale. If this parameter is set to false the Struts application can use the Request processor's processLocale method for controlling locale or set the locale in a Struts action; otherwise, it uses the portal's locale and also supports dynamic changes. Default is true.

      WelcomeFileSearchPath
      This configuration parameter allows customizing the initial view page search.

    Servlet mapping
    In a portlet, use a servlet URL mapping for the portlet. So, one would typically use a path prefix servlet mapping similar to the following.
    <servlet-mapping id="ServletMapping_1">
         <servlet-name>MyStrutsApp</servlet-name>
         <url-pattern>/Struts/*</url-pattern>
    </servlet-mapping>

    The typical Struts application uses an extension mapping. The Struts example uses extension mapping and it is expected that most Struts applications use the extension mapping "*.do". In the normal Struts case, this means that URIs ending in "*.do" are directed to the Struts servlet. Struts provides a single servlet that use (or subclass) for all of the Struts applications. When to cause control to be given to a Struts Action when a link is selected or form submitted, use the extension from the extension mapping, for example "*.do" on the URI so the processing is routed to the Struts ActionServlet. Other URIs, such as those for JSPs, do not have this extension and, thus, would not be routed through the Action Servlet for processing.

    A Struts application, which is itself a servlet application, also requires a servlet mapping. Although the Struts portlet already has a servlet mapping as shown previously, you still must identify what to use as a Struts action mapping so that paths that must be treated as Struts actions can be recognized. To specify the pseudo servlet mapping used by Struts, specify it as a servlet initialization parameter in web.xml, as follows:

     <init-param>
         <param-name>struts-servlet-mapping</param-name>
         <param-value>*.do</param-value>
     </init-param>

    The Struts Portlet Framework supports the same servlet mappings modes as the servlet-based Struts application. However, the current Struts implementation supports extension mapping for the module implementation. Since the portal server implementation uses modules for the mode and markup support, use the extension mapping.


Configure the Struts application for the standard portlet container

In the standard container the Struts application is configured in the portlet deployment descriptor. The portlet class and init parameters are specified in the portlet deployment description. In the standard container, the only configuration in the web deployment descriptor is the welcome file list and the tag library (taglib) elements. The portlet class specified in the portlet deployment descriptor must be the com.ibm.portal.struts.portlet.StrutsPortlet class or subclass.

   <portlet>           <portlet-class>com.ibm.portal.struts.portlet.StrutsPortlet</portlet-class>
   </portlet>

If subclassing the StrutsPortlet, the subclass class name must be designated as the <portlet-class/>.

Initialization parameters

The following is a list of names of the initialization parameters that can be configured in the web deployment descriptor for Struts portlets, with the <init-param> element):

    IncludesSearchPath
    Indicates a more fine-tuned search path for including a file. If this value is not specified, then PortletContext.include() is used instead.

    ModuleSearchPath
    Indicates the search path for Struts modules, default value is the markupName and mode. See Support for multiple Struts applications for more information

    NamescopeFormName
    The default behavior is for the Struts form tag to namescope the name of the portlet. Setting this parameter to false allows the behavior to be overridden.

    NamescopeServletContext
    This allows the WpsStrutsPortlet to be defined in the web deployment descriptor more than once by namescoping the parameters in the servlet context.

    struts-servlet-mapping
    Identifies a Struts action mapping so that paths that must be treated as Struts actions can be recognized. See Servlet mapping for further details.

    UseGroupsForAccess
    Configures the Struts portlet to use portal server group names as if they were role names. Struts uses roles to determine access to an Action. However, WebSphere Portal V 4.2 does not support roles. Set true to configure the Struts application to use the portal's group names as if they were role names to emulate role-based access control.

    UsePortalsLocale
    This parameter allows a Struts application to override default behavior of using the portal's locale. If this parameter is set to false, the Struts application can use the Request processor's processLocale method for controlling locale or set the locale in a Struts action. Otherwise, it uses the portal's locale and also supports dynamic changes. Default is true.

    WelcomeFileSearchPath
    This configuration parameter allows customizing the initial view page search.


Set an initial view

The Struts application must specify what the initial view is for the application. The typical way the initial screen is specified is through the welcome file list. The Struts Portlet Framework supports the welcome file list configuration, and has some additional features. The servlet implementation of the welcome file list only supports JSP and HTML pages. The Struts Portlet Framework supports a JSP or HTML welcome file, and also allows a Struts action to be specified as the welcome file. See Example 1 for implementation details.

The alternative method allows Welcome files to be configured on a per portlet basis as a configuration parameter in the portlet deployment descriptor portlet.xml. The default search looks for the initial view file per portlet mode. The other feature in the Struts Portlet Framework is the support for modules. A unique welcome file must be configured for each module by specifying the application prefix. For example, to support the view mode for the markup WML, a welcome file wml/view can be specified. See Example 2 for implementation details.

Figure 1. Example 1: Welcome file list specified in the file web.xml

<welcome-file-list>
  <welcome-file>index.jsp</welcome-file>
  <welcome-file>help/index.jsp</welcome-file>
  <welcome-file>wml/view/index.jsp</welcome-file>
</welcome-file-list>

Figure 2. Example 2: Welcome file list specified on a per portlet basis (standard portlets)

      <portlet-preferences>
         <preference>
            <name>viewMode.page</name>
            <value>portlet1/welcome.jsp</value>
         </preference>
         <preference>
            <name>editMode.page</name>
            <value>html/edit/index.jsp</value>
         </preference>
      </portlet-preferences>

Figure 3. Example 3: Welcome file list specified on a per portlet basis (IBM)

           <config-param>
 <param-name>viewMode.page</param-name>
 <param-value>portlet1/welcome.jsp</param-value>
            </config-param>
            <config-param>
 <param-name>editMode.page</param-name>
 <param-value>portlet1/edit.jsp</param-value>
            </config-param>

  • A welcome file entry must be configured for each module. The welcome file entry is the initial screen shown when first switching to that module.
  • The default Struts configuration, which has a "" prefix, is used any time a module prefix is not found.


Use modes

The Struts Portlet Framework is set up to use the mode and markup to find the Struts configuration. However, if we do not want to use a Struts application in one of the modes, the Struts portlet (Wps)StrutsPortlet must be subclassed. The appropriate service() method must be overridden to implement the wanted behavior. For example, if the developer wants a help mode that does not use a Struts application, then the doHelp() method must be implemented in a subclass.

Portlet modes can be supported by the Struts Portlet framework. The Struts Portlet Framework stores the IViewCommand objects on a per mode basis. That means that an application that supports view and edit mode has an IViewCommand object for view and edit mode. The welcome file list is typically used for the initial page when entering a mode.

The SPFLegacyMultipleModules.war example for the IBM container and the SPFStandardMultipleModules.war example for the standard portlet container demonstrate support for edit mode. The Module 1 portlet implements an edit mode wizard that steps through three screens. The example also demonstrates how to use a StrutsActionForward so the IViewCommand object for the last page of the wizard can be marked for removal on a mode change. This allows the IViewCommand object for edit mode to be deleted when the user switches from edit mode back to view. The anticipated use is the user is entering data in edit mode and the configuration data is submitted to be stored. The last page displays the data has been successfully stored. The user then leaves edit mode with the skin. If the user goes back into edit mode, they do not want to see the message the data was successfully stored. Since the command was deleted, the welcome file list entry can be used to start the wizard again. This feature also reduces the number of attributes stored in session.

      <action path="/nextEditPage2" type="com.ibm.wps.struts.example.multipleapps.actions.ForwardAction">
              <forward className="com.ibm.wps.struts.action.StrutsActionForward"
         name="success" path="/edit3.jsp">
        <set-property property="removeOnModeChange"
        value="true"/>
 </forward>
      </action>

The Struts example application demonstrates support for help mode. A Struts configuration was added to the web deployment descriptor, web.xml, to demonstrate help mode. This mode is entered when the user clicks the help button for the Struts example portlet. The following code fragment from the web deployment descriptor demonstrates how to configure the struts-configuration to support help mode.

<init-param>
 <param-name>config/html/help</param-name>
 <param-value>/WEB-INF/html/help/struts-config.xml</param-value>
</init-param>

The search path set in the web deployment descriptor includes mode, which enables a separate Struts configuration for a mode.

<init-param>
 <param-name>ModuleSearchPath</param-name>
 <param-value>markupName, porletMode</param-value>
</init-param>

The welcome file list defines the welcome file for the help mode, as follows:

<welcome-file-list>
 <welcome-file>index.jsp</welcome-file>
 <welcome-file>html/help/index.jsp</welcome-file>
 <welcome-file>wml/view/index.jsp</welcome-file>
</welcome-file-list>


Support for devices

The Struts Portlet Framework's support of devices was flexible. The way the configuration and JSP files are placed in the directory structure must be tolerant of the devices that must be supported. Some applications can support HTML browsers and need a single Struts configuration file. Other applications can support multiple markups and locales but do not need to know specifics about the device itself, while other implementations need unique implementations for each of the supported devices.

This support requires extension mapping. The prefix mapping supports only a single configuration file.

WebSphere Portal is designed to allow portlets to access information about the client device, such as locale and markup language supported with the Client interface. The Struts support for modes and markups was implemented by allowing a configuration parameter to specify the fields in the client object interesting. The Client object is treated like a bean, where the field value corresponds to a get method in the Client object. This allows developers to specify the fields in the Client object necessary to their device support.

The standard portlet container does not have a Client object but the following fields are supported:

  • markupName
  • locale
  • portletMode

There are two paths that can be specified for supporting modes and device types (clients). The first path is the search path, and that path is used to specify the module to use. The search path locates the appropriate Struts configuration to use and is the prefix used as the base directory for the necessary JSPs. The default search path is markupName, portletMode. This searches for a configuration based on the current markup and the portlet mode.

<init-param>
  <param-name>ModuleSearchPath</param-name>
  <param-value>markupName, portletMode</param-value>
</init-param>
For example, if a desktop browser is used and the user is in view mode, then the search path would be:

  • html/view
  • html
  • "" ( default configuration )

And if the Client object specified "wml" as the markupName then the search path would be:

  • wml/view
  • wml
  • "" ( default configuration )

The search path is checked against all of the prefixes for the ModuleConfig objects for a match. The modules are configured in the web deployment descriptor, web.xml, by specifying a prefix for a Struts configuration. For example, a module for the WML markup in view mode would be configured by adding a configuration to the web deployment descriptor like:

<init-param>
   <param-name>config/wml/view</param-name>
   <param-value>/WEB-INF/wml/view/struts-config.xml</param-value>
</init-param>

If the wml/view module is selected, the corresponding JSPs are searched for under the wml/view directory of the Struts application WAR file.

This is a good start for separating the files for different markups and modes, but this granularity is probably not enough to deal with all available devices, or even locales. We can modify this search path to have a finer granularity. For example, we can create a unique module for every phone they support.

The search path of markupName, portletMode, locale, manufacturer, model, and version can be used. This offers a fine-grained deployment of the JSPs. The problem with this approach is that most of the JSPs would probably be the same for each of the devices. There are probably a few that must be modified for each device, but this approach does not allow sharing.

This is why two paths are offered, search and include. The search path is used to find the module. This would be for applications that can use a common configuration, share actions, and some of the JSPs. The include path can then be used to look for specific implementations of the JSP and if not found, fall back to a common file.

Take the following include path for including JSPs that are dependent on the device.

<init-param>
   <param-name>IncludesSearchPath</param-name>
   <param-value>manufacturer, model, version</param-value>
</init-param>

This would search for the file relative to the module and then take the requested fields into account. If the search path found the wml/view module and the file index.jsp is requested, then the previous search path for an ACME T400 would be as follows:

  • wml/view/Acme/T400/index.jsp
  • wml/view/Acme/index.jsp
  • wml/view/index.jsp

That version did not show up in the search. The default client configuration for the T400 did not have one defined. If one was configured later, then it would be used.

Portal aggregation is flexible in how the differences between devices are supported. The common features are supported through the search path; all WML devices in view mode in a locale. The subtitle differences between devices would be supported through the file search of the include path. The common versions of the JSPs would be at a root level, and specific files would be in subordinate directories.

The Struts example includes several tags, two of which required a minor change to support modules. The LinkSubscriptionTag and LinkUserTag tags had to be modified so the current ModuleConfig's prefix had to be added to the computed URL.


Globalization support

The Struts Portlet Framework supports i18n using resource bundles. Each Struts application can specify a message resource. The Java resource bundle implementation determines the resource bundle to use based on the locale and variant. The Struts application typically uses the message tag to include translated text from the application-supplied resource bundle.

<init-param>
  <param-name>IncludesSearchPath</param-name>
  <param-value>locale</param-value>
</init-param>

The Struts framework was designed to give the application control over locale using a locale object set in session with a known key. The Struts RequestProcessor sets the locale object for each user during the processLocale() method. The processLocale() method sets the locale object using the key Globals.LOCALE_KEY if the feature is enabled through the Struts configuration file and the attribute was not already set in session.

A setting on the controller element available in the Struts configuration file controls the locale support in Struts. The support can be turned off, which stops the locale processing in the Request processor processLocale() method.

WebSphere Portal supports dynamic changes to the locale. Portlets must use the locale object that is obtained through the PortletRequest object for the locale setting. The Struts Portlet Framework sets the locale object in the session with the key Globals.LOCALE_KEY during the actionPerformed() and service() methods. The support is implemented by calling the (Wps)StrutsPortlet processLocale() method, which sets the locale object if one is not found or the locale is different from the one already in session. This assures that a portlet written using the Struts Portlet Framework uses the correct locale.

Locale support can also be customized. The (Wps)StrutsPortlet processLocale() method can be overridden for a customized implementation. The invocation of (Wps)StrutsPortlet processLocale() can also be stopped by adding the following init-parameter to the web deployment descriptor for the application.

<init-param>
  <param-name>UsePortalsLocale</param-name>
  <param-value>false</param-value>
</init-param>         

However, in most cases the portlet must use the default implementation.


Use the IBM container

WebSphere Portal also provides an implementation to find globalized JSPs using the include() method on PortletContext. PortletContext inserts the locale into the path to locate the locale-specific JSP. See Generating markup for multiple devices, markups, and languages.

The Struts Application can be deployed to use the portal server's aggregation method to find globalized JSPs, instead of a resource bundle for each locale. The Struts Portlet Framework uses the PortletContext.include() on the existing container to include JSP pages, so both methods of globalization are supported.

PortletContext.include() searches for locale-specific files by inserting the markup and locale name in the path. This behavior can be configured through an initialization parameter in the web deployment descriptor. An include search path can be specified that controls how the includes are located. For example, the default implementation would be markup, locale but can be changed to just locale if required. The mode and markup support may have been already configured to include markup, so this configuration allows the markup to not be needed a second time.


WML support

Because WebSphere Portal supports pervasive devices, such as WAP phones, the example was configured to support a generic WML device. Adding a Struts configuration for WML devices supports the view mode for a WML device. The following code fragment demonstrates how to set up the struts-configuration for the view mode for WML markup.

<init-param>
 <param-name>config/wml/view</param-name>
 <param-value>/WEB-INF/wml/view/struts-config.xml</param-value>
</init-param>

The search path set up in the web deployment descriptor, takes markup, mode, and locale into account. When a WAP device connects to a portal server, the markup is WML, and the mode is view. This example does not use the locale that is requested.

The welcome file list also defines the welcome file for the wml/view mode.

<welcome-file-list>
 <welcome-file>index.jsp</welcome-file>
 <welcome-file>html/help/index.jsp</welcome-file>
 <welcome-file>wml/view/index.jsp</welcome-file>
</welcome-file-list>

For more information about WML support in the Struts Portlet Framework, see Changes to Struts JSPs.


Logging

The Struts Portlet Framework uses the Commons-Logging interface for a logging facility. The Struts Portlet Framework was supplied an implementation of the Commons-Logging Log interface used to map the trace messages to the logging facility used by the portal server. This file is normally found in the PORTAL_HOME/log directory. Setting properties in the WP_PROFILE/PortalServer/config/config/log.properties file enables trace logging. The trace string for tracing a Struts portlet application can be configured in log.properties. The trace string can be modified to add or remove classes. The entire trace string must be on one line in log.properties.

The logging in WebSphere Portal typically creates a logging object per class and the trace messages open the log class the message is from. It is convenient to determine where a trace message originated from and also allows enabling the tracing on certain classes.

The typical trace string configured in the log.properties file for tracing a Struts application would be as the following examples (all on one line). This can be modified to add or remove classes.

    IBM container:

    traceString= org.apache.struts.*=all: com.ibm.wps.portlets.struts.*=all: com.ibm.wps.struts.common.*=all: com.ibm.wps.struts.base.*=all

    Some of the Apache source uses a string to specify the class name and, in some cases, this string is not be a valid class. In those cases the class name in the trace message is com.ibm.wps.portlets.struts.logging.WpsStrutsTraceLogger. This package or class must be specified in the traceString to account for these occasions.

    The log messages from Struts use the Portal Server's logging facility when logging is enabled. When this is the case, the log messages from Struts do not open the correct method name as part of the log message. There is a configuration parameter to enable correcting this problem, but this is an expensive operation. This feature is not required as much with the logging changes implemented in this release.

    JSR-compliant container:

    traceString= org.apache.struts.*=all: com.ibm.portal.struts.*=all: com.ibm.wps.struts.common.*=all: com.ibm.wps.struts.base.*=all

    Customize logging

    The Struts Portlet Framework specifies the commons logging Log Factory in the META-INF/services directory. In the samples, the org.apache.commons.logging.LogFactory file specifies the default logger the Struts Portlet Framework uses. The log factory class name is dependent on the WebSphere Portal container. The org.apache.commons.logging.LogFactory file can be edited to specify other commons log factories.

    Use the default logging implementation class: Struts Portlet Framework 5.0.3 or later Struts Portlet Framework 5.0.3 and later no longer use the System property org.apache.commons.logging.LogFactory to specify the log factory class. The commons log factory can be specified either in the META-INF/services directory or the commons-logging.properties file that must be found through the class path. The suggested way to specify the commons log factory is to through the META-INF/services directory of the WAR file.

    IBM container with a Struts Portlet Framework version prior to 5.0.3: Versions of the Struts Portlet Framework before SPF 5.0.3 set the logging implementation class with the System property org.apache.commons.logging.LogFactory. The portlet initialization method, init, in com.ibm.wps.portlets.struts.WpsStrutsPortlet calls the setCommonsLogFactory method.

    public void setCommonsLogFactory()
    {
       String methodName = "setCommonsLogFactory";
       s_traceLogger.text( WpsStrutsTraceLogger.TRACE, methodName,     "Set common logging to use StrutsLogFactory" );
       System.setProperty( "org.apache.commons.logging.LogFactory",    "com.ibm.wps.portlets.struts.logging.StrutsLogFactory");
    }

    A portlet must not use this mechanism, as the system property affects other applications in the WAS. If an older version of the Struts Portlet Framework is used, first the WpsStrutsPortlet must be extended and the setCommonsLogFactory must be implemented to do nothing. Then modify the application to specify the commons log factory through the org.apache.commons.logging.LogFactory file in the META-INF/services directory of the application.

    Struts Portlet Framework version 5.0.3 or later Log Factory's class name

    Standard portlet container: org.apache.commons.logging.LogFactory

    IBM portlet container: com.ibm.wps.portlets.struts.logging.StrutsLogFactory

    Overriding the default logging implementation class
    Struts portlet developers can override the default logging implementation class. Depending on the version of Struts, the implementation varies.

    Struts Portlet Framework 5.0.3 or later There are two ways to customize the logger. The first and recommended option is to specify the log factory in the org.apache.commons.logging.LogFactory file in the META-INF/services directory. The Commons Logging implementation checks the META-INF/services directory before looking for the commons-logging.properties file in the class path to determine the class name of the LogFactory. The second option is to specify the commons-logging.properties file in the application's class path. The org.apache.commons.logging.LogFactory file can be updated to specify the required LogFactory.

    Version 5.0.3 of the Struts Portlet Framework used the commons-logging.properties file to specify the logger, and this file was packaged in the wp.struts-commons-logging.jar. Specifying the log factory in the META-INF/services directory takes precedent over the log factory specified in the wp.struts-commons-logging.jar file.

    IBM container with a Struts Portlet Framework version prior to 5.0.3: To override the default logging implementation class, developers can extend com.ibm.wps.portlets.struts.WpsStrutsPortlet and override the setCommonsLogFactory method. The developer could remove the call to set the org.apache.commons.logging.LogFactory System property in setCommonsLogFactory, and create the file org.apache.commons.logging.LogFactory in the META-INF/services directory (or the file commons-logging.properties in the WEB-INF/classes directory of the application to determine the logging implementation class. The META-INF/services directory is the preferred method.

    The portlet web deployment descriptor will then need to be updated to specify the WpsStrutsPortlet subclass as the servlet class.

    Logging conflict between new and old versions of Struts portlets
    The JCL determines the logging implementation by first looking for the System property org.apache.commons.logging.LogFactory. If the System property has not been set, it then looks for the org.apache.commons.logging.LogFactory file in the META-INF/services directory and then for commons-logging.properties in the classpath.

    The value of the System property becomes available to all portlets once it is set, and this would determine the logging implementation class for the portlets on the page. There would be no effect on the logging if the default logging implementation is used by all portlets. However, if the logging implementation class for a portlet is set in a custom common-logging.properties file, it would be ignored. To overcome this, the developer would need to override the method, which sets the System property. See the section Overriding the default logging implementation class for more details.

    Commons Logging JAR file
    The WebSphere Application Server includes a version of the commons-logging.jar file and specifies the default commons logger to be the com.ibm.ws.commons.logging.TrLogFactory class. If the Struts portlet does not specify a log factory, then the default log factory of TrLogFactory is used. However, if the application includes a version of commons-logging, then a ClassCastException results. This release of the Struts Portlet Framework no longer includes commons-logging.jar, but instead uses the version included in the Application Server. Older applications can continue to use the commons-logging.jar file that is packaged with the Struts Portlet Framework if the application specifies a logger, which is the typical case.


Changes to the Struts configuration file

The Struts configuration used by Struts portlets references the 1.1 version of the DTD.

<!DOCTYPE struts-config PUBLIC
          "-//Apache Software Foundation//DTD Struts Configuration 1.1//EN"
          "http://jakarta.apache.org/struts/dtds/struts-config_1_1.dtd">

For the Struts Portlet Framework operate properly, the RequestProcessor must be configured. The RequestProcessor is responsible for the main function of processing a request. The default RequestProcessor can be overridden in the struts-config.xml with the controller element. In the struts-config.xml, the following portal server RequestProcessor must be specified:

    Standard portlet container:

    <controller processorClass="com.ibm.portal.struts.portlet.WpRequestProcessor"> </controller>

    IBM portlet container:

    <controller processorClass="com.ibm.wps.portlets.struts.WpsRequestProcessor"> </controller>

We can also extend the Struts RequestProcessor in order to extend the function of Struts. If we place the path to the RequestProcessor in the controller element in the struts-config file, the application does not work properly in the portlet environment. Instead, what we must do is have the RequestProcessor class extend the WpsRequestProcessor rather than the normal Struts RequestProcessor.

The following are the methods overridden in WpsRequestProcessor:

  • processLocale
  • processActionPerform()
  • processActionForm()
  • processActionForward()
  • processPath()
  • processRoles()
  • processMapping()
  • processValidate()
  • doForward()
  • doInclude()
  • getMapping()

If we override any of the methods listed previously, we must make sure to start the super class version of the method from within the method.

There are existing Struts Extensions, which require us to use their RequestProcessor. Clearly, we cannot use their RequestProcessor and the WpsRequestProcessor at the same time. Instead, we must get the source to that RequestProcessor and following the approach described.


Tiles support

Struts integrates the Tiles package for creating views. A Tiles sample is included with the Struts Portlet Framework that demonstrates how to configure Tiles in the Struts Portlet Framework. Tiles requires a specific Request processor configured through a plug-in. The following is from the Struts configuration to show how to configure Tiles for a Struts application deployed in WebSphere Portal.

    Standard portlet container:

    <!-- add the Tiles plugin. --> <plug-in className="com.ibm.portal.struts.plugins.WpTilesPlugin"> <set-property property="definitions-config" value="/WEB-INF/conf/tiles-def.xml"/> <set-property property="definitions-debug" value="2"/> <set-property property="definitions-parser-details" value="2"/> <set-property property="definitions-parser-validate" value="true"/> </plug-in>

    The Tiles plug-in requires that compatible request processor is configured in the controller element. The WpTilesPlugin was written to accept the default Struts RequestProcessor, WpStrutsRequestProcessor, or the WpTilesRequestProcessor.

    IBM portlet container:

    <!-- add the Tiles plugin. --> <plug-in className="com.ibm.wps.portlets.struts.plugins.WpsStrutsTilesPlugin"> <set-property property="definitions-config" value="/WEB-INF/conf/tiles-def.xml"/> <set-property property="definitions-parser-details" value="2"/> <set-property property="definitions-parser-validate" value="true"/> </plug-in>

    The Tiles plug-in requires that compatible request processor is configured in the controller element. The WpsStrutsTilesPlugin was written to accept the default Struts RequestProcessor, WpsStrutsRequestProcessor, or the WpsStrutsTilesRequestProcessor.


Parent Struts Portlet Framework