public class ActionFileUploadInterceptor extends AbstractFileUploadInterceptor
Interceptor that is based off of MultiPartRequestWrapper
, which is automatically applied for any request that
includes a file when the support for multi-part request is enabled,
see Disabling file upload.
You can get access to these files by implementing UploadedFilesAware
interface. The interceptor will then
call UploadedFilesAware.withUploadedFiles(List)
when there are files which were accepted during the upload process.
This interceptor will add several field errors, assuming that the action implements ValidationAware
.
These error messages are based on several i18n values stored in struts-messages.properties, a default i18n file
processed for all i18n requests. You can override the text of these messages by providing text for the following
keys:
Interceptor parameters:
Example code:
<action name="doUpload" class="com.example.UploadAction"> <interceptor-ref name="actionFileUpload"/> <interceptor-ref name="basicStack"/> <result name="success">good_result.jsp</result> </action>
You must set the encoding to multipart/form-data
in the form where the user selects the file to upload.
<s:form action="doUpload" method="post" enctype="multipart/form-data"> <s:file name="upload" label="File"/> <s:submit/> </s:form>
And then in your action code you'll have access to the File object if you provide setters according to the naming convention documented in the start.
package com.example; import java.io.File; import com.opensymphony.xwork2.ActionSupport; import org.apache.struts2.action.UploadedFilesAware; public UploadAction extends ActionSupport implements UploadedFilesAware { private UploadedFile uploadedFile; private String contentType; private String fileName; private String originalName; @Override public void withUploadedFiles(ListuploadedFiles) { if (!uploadedFiles.isEmpty() > 0) { this.uploadedFile = uploadedFiles.get(0); this.fileName = uploadedFile.getName(); this.contentType = uploadedFile.getContentType(); this.originalName = uploadedFile.getOriginalName(); } } public String execute() { //... return SUCCESS; } }
ConditionalInterceptor.LegacyAdapter
Modifier and Type | Field and Description |
---|---|
protected static org.apache.logging.log4j.Logger |
LOG |
STRUTS_MESSAGES_BYPASS_REQUEST_KEY, STRUTS_MESSAGES_ERROR_CONTENT_TYPE_NOT_ALLOWED_KEY, STRUTS_MESSAGES_ERROR_FILE_EXTENSION_NOT_ALLOWED_KEY, STRUTS_MESSAGES_ERROR_FILE_TOO_LARGE_KEY, STRUTS_MESSAGES_ERROR_UPLOADING_KEY, STRUTS_MESSAGES_INVALID_CONTENT_TYPE_KEY, STRUTS_MESSAGES_INVALID_FILE_KEY
Constructor and Description |
---|
ActionFileUploadInterceptor() |
Modifier and Type | Method and Description |
---|---|
String |
intercept(ActionInvocation invocation)
Override to handle interception
|
acceptFile, applyValidation, getTextMessage, getTextMessage, getTextProvider, isNonEmpty, setAllowedExtensions, setAllowedTypes, setContainer, setMatcher, setMaximumSize
intercept, shouldIntercept, shouldIntercept
destroy, init, setDisabled
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
adapt
adapt
destroy, init
public String intercept(ActionInvocation invocation) throws Exception
AbstractInterceptor
intercept
in class AbstractInterceptor
Exception
Copyright © 2000–2024 Apache Software Foundation. All rights reserved.