Package org.apache.struts2.convention
Class ConventionUnknownHandler
java.lang.Object
org.apache.struts2.convention.ConventionUnknownHandler
- All Implemented Interfaces:
- UnknownHandler
This class is the default unknown handler for all of the Convention plugin integration with XWork. This handles instances when a URL doesn't have an action associated with it but does a viable result and also the instance where an action returns a result code that isn't already configured but there is a viable result for the code.
This class also handles all of the index actions using redirects and actions in nested packages. For example, if there is an action /foo/index and the URL /foo is used, this will render the index action in the /foo namespace.
- 
Nested Class SummaryNested Classes
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Configurationprotected Stringprotected ObjectFactoryprotected PackageConfigprotected ResultMapBuilderprotected jakarta.servlet.ServletContext
- 
Constructor SummaryConstructorsConstructorDescriptionConventionUnknownHandler(Configuration configuration, ObjectFactory objectFactory, jakarta.servlet.ServletContext servletContext, Container container, String defaultParentPackageName, String redirectToSlash, String nameSeparator) Constructs the unknown handler.
- 
Method SummaryModifier and TypeMethodDescriptionprotected ActionConfigbuildActionConfig(String path, ResultTypeConfig resultTypeConfig) protected ResultbuildResult(String path, String resultCode, ResultTypeConfig config, ActionContext invocationContext) protected Stringcanonicalize(String path) protected StringdeterminePath(ActionConfig actionConfig, String namespace) Determines the result path prefix that the request URL is for, minus the action name.protected ConventionUnknownHandler.ResourcefindResource(Map<String, ResultTypeConfig> resultsByExtension, String... parts) Finds a resource using the given path parts and all of the extensions in the map.protected ResultfindResult(String path, String resultCode, String ext, ActionContext actionContext, Map<String, ResultTypeConfig> resultsByExtension) handleUnknownAction(String namespace, String actionName) handleUnknownActionMethod(Object action, String methodName) Not usedhandleUnknownResult(ActionContext actionContext, String actionName, ActionConfig actionConfig, String resultCode) protected String
- 
Field Details- 
configuration
- 
objectFactory
- 
servletContextprotected jakarta.servlet.ServletContext servletContext
- 
resultMapBuilder
- 
defaultParentPackageName
- 
parentPackage
- 
allowedMethods
 
- 
- 
Constructor Details- 
ConventionUnknownHandlerpublic ConventionUnknownHandler(Configuration configuration, ObjectFactory objectFactory, jakarta.servlet.ServletContext servletContext, Container container, String defaultParentPackageName, String redirectToSlash, String nameSeparator) Constructs the unknown handler.- Parameters:
- configuration- The XWork configuration.
- objectFactory- The XWork object factory used to create result instances.
- servletContext- The servlet context used to help build the action configurations.
- container- The Xwork container
- defaultParentPackageName- The default XWork package that the unknown handler will use as the parent package for new actions and results.
- redirectToSlash- A boolean parameter that controls whether or not this will handle unknown actions in the same manner as Apache, Tomcat and other web servers. This handling will send back a redirect for URLs such as /foo to /foo/ if there doesn't exist an action that responds to /foo.
- nameSeparator- The character used as word separator in the action names. "-" by default
 
 
- 
- 
Method Details- 
handleUnknownAction- Specified by:
- handleUnknownActionin interface- UnknownHandler
- Throws:
- StrutsException
 
- 
findResourceprotected ConventionUnknownHandler.Resource findResource(Map<String, ResultTypeConfig> resultsByExtension, String... parts) Finds a resource using the given path parts and all of the extensions in the map.- Parameters:
- resultsByExtension- Map of extension to result type config objects.
- parts- The parts of the resource.
- Returns:
- The resource path or null.
 
- 
canonicalize
- 
buildActionConfig
- 
handleUnknownResultpublic Result handleUnknownResult(ActionContext actionContext, String actionName, ActionConfig actionConfig, String resultCode) throws StrutsException - Specified by:
- handleUnknownResultin interface- UnknownHandler
- Throws:
- StrutsException
 
- 
findResultprotected Result findResult(String path, String resultCode, String ext, ActionContext actionContext, Map<String, ResultTypeConfig> resultsByExtension) 
- 
buildResultprotected Result buildResult(String path, String resultCode, ResultTypeConfig config, ActionContext invocationContext) 
- 
string
- 
determinePathDetermines the result path prefix that the request URL is for, minus the action name. This includes the base result location and the namespace, with all the slashes handled.- Parameters:
- actionConfig- (Optional) The might be a ConventionActionConfig, from which we can get the default base result location of that specific action.
- namespace- The current URL namespace.
- Returns:
- The path prefix and never null.
 
- 
handleUnknownActionMethodNot used- Specified by:
- handleUnknownActionMethodin interface- UnknownHandler
 
 
-