Struts 2 - Uploads de arquivos
A estrutura do Struts 2 fornece suporte integrado para processamento de upload de arquivo usando "Upload de arquivo baseado em formulário em HTML". Quando um arquivo é carregado, ele normalmente é armazenado em um diretório temporário e deve ser processado ou movido por sua classe Action para um diretório permanente para garantir que os dados não sejam perdidos.
Note - Os servidores podem ter uma política de segurança em vigor que o proíba de gravar em diretórios que não sejam o diretório temporário e os diretórios que pertencem ao seu aplicativo da web.
O upload de arquivos no Struts é possível através de um interceptor pré-definido chamado FileUpload interceptor que está disponível por meio da classe org.apache.struts2.interceptor.FileUploadInterceptor e incluído como parte dadefaultStack. Ainda assim, você pode usar isso em seu struts.xml para definir vários parâmetros, como veremos a seguir.
Criar arquivos de visualização
Vamos começar criando nossa visão que será necessária para navegar e carregar um arquivo selecionado. Então, vamos criar umindex.jsp com formulário de upload de HTML simples que permite ao usuário fazer upload de um arquivo -
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>File Upload</title>
</head>
<body>
<form action = "upload" method = "post" enctype = "multipart/form-data">
<label for = "myFile">Upload your file</label>
<input type = "file" name = "myFile" />
<input type = "submit" value = "Upload"/>
</form>
</body>
</html>
Há alguns pontos dignos de nota no exemplo acima. Primeiro, o enctype do formulário é definido comomultipart/form-data. Isso deve ser definido para que os uploads de arquivos sejam tratados com êxito pelo interceptor de upload de arquivos. O próximo ponto a ser observado é o método de ação do formulárioupload e o nome do campo de upload de arquivo - que é myFile. Precisamos dessas informações para criar o método de ação e a configuração do struts.
A seguir, vamos criar um arquivo jsp simples success.jsp para exibir o resultado de nosso upload de arquivo, caso seja um sucesso.
<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>
<html>
<head>
<title>File Upload Success</title>
</head>
<body>
You have successfully uploaded <s:property value = "myFileFileName"/>
</body>
</html>
A seguir estará o arquivo de resultado error.jsp caso haja algum erro no upload do arquivo -
<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>
<html>
<head>
<title>File Upload Error</title>
</head>
<body>
There has been an error in uploading the file.
</body>
</html>
Criar classe de ação
A seguir, vamos criar uma classe Java chamada uploadFile.java que cuidará de enviar o arquivo e armazená-lo em um local seguro -
package com.tutorialspoint.struts2;
import java.io.File;
import org.apache.commons.io.FileUtils;
import java.io.IOException;
import com.opensymphony.xwork2.ActionSupport;
public class uploadFile extends ActionSupport {
private File myFile;
private String myFileContentType;
private String myFileFileName;
private String destPath;
public String execute() {
/* Copy file to a safe location */
destPath = "C:/apache-tomcat-6.0.33/work/";
try {
System.out.println("Src File name: " + myFile);
System.out.println("Dst File name: " + myFileFileName);
File destFile = new File(destPath, myFileFileName);
FileUtils.copyFile(myFile, destFile);
} catch(IOException e) {
e.printStackTrace();
return ERROR;
}
return SUCCESS;
}
public File getMyFile() {
return myFile;
}
public void setMyFile(File myFile) {
this.myFile = myFile;
}
public String getMyFileContentType() {
return myFileContentType;
}
public void setMyFileContentType(String myFileContentType) {
this.myFileContentType = myFileContentType;
}
public String getMyFileFileName() {
return myFileFileName;
}
public void setMyFileFileName(String myFileFileName) {
this.myFileFileName = myFileFileName;
}
}
o uploadFile.javaé uma aula muito simples. O importante a observar é que o interceptor FileUpload, junto com o Parameters Interceptor, faz todo o trabalho pesado para nós.
O interceptor FileUpload disponibiliza três parâmetros para você por padrão. Eles são nomeados no seguinte padrão -
[your file name parameter] - Este é o arquivo real que o usuário carregou. Neste exemplo, será "myFile"
[your file name parameter]ContentType- Este é o tipo de conteúdo do arquivo que foi carregado. Neste exemplo, será "myFileContentType"
[your file name parameter]FileName- Este é o nome do arquivo que foi carregado. Neste exemplo, será "myFileFileName"
Os três parâmetros estão disponíveis para nós, graças aos Struts Interceptors. Tudo o que temos que fazer é criar três parâmetros com os nomes corretos em nossa classe Action e automaticamente essas variáveis são conectadas automaticamente para nós. Portanto, no exemplo acima, temos três parâmetros e um método de ação que simplesmente retorna "sucesso" se tudo correr bem, caso contrário, retorna "erro".
Arquivos de configuração
A seguir estão as propriedades de configuração do Struts2 que controlam o processo de upload de arquivos -
Sr. Não | Propriedades e descrição |
---|---|
1 | struts.multipart.maxSize O tamanho máximo (em bytes) de um arquivo a ser aceito como upload de arquivo. O padrão é 250M. |
2 | struts.multipart.parser A biblioteca usada para carregar o formulário multiparte. Por padrão éjakarta |
3 | struts.multipart.saveDir O local para armazenar o arquivo temporário. Por padrão, é javax.servlet.context.tempdir. |
Para alterar qualquer uma dessas configurações, você pode usar constant tag no arquivo struts.xml de seus aplicativos, como fiz para alterar o tamanho máximo de um arquivo a ser carregado.
Deixe-nos ter nosso struts.xml como segue -
<?xml version = "1.0" Encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "true" />
<constant name = "struts.multipart.maxSize" value = "1000000" />
<package name = "helloworld" extends = "struts-default">
<action name = "upload" class = "com.tutorialspoint.struts2.uploadFile">
<result name = "success">/success.jsp</result>
<result name = "error">/error.jsp</result>
</action>
</package>
</struts>
Desde a, FileUploadinterceptor é uma parte da pilha de interceptores padrão, não precisamos configurá-lo explicitamente. Mas, você pode adicionar a tag <interceptor-ref> dentro de <action>. O interceptor fileUpload leva dois parâmetros(a) maximumSize e (b) allowedTypes.
O parâmetro maximumSize define o tamanho máximo de arquivo permitido (o padrão é aproximadamente 2 MB). O parâmetro allowedTypes é uma lista separada por vírgulas de tipos de conteúdo aceito (MIME), conforme mostrado abaixo -
<action name = "upload" class = "com.tutorialspoint.struts2.uploadFile">
<interceptor-ref name = "basicStack">
<interceptor-ref name = "fileUpload">
<param name = "allowedTypes">image/jpeg,image/gif</param>
</interceptor-ref>
<result name = "success">/success.jsp</result>
<result name = "error">/error.jsp</result>
</action>
A seguir está o conteúdo de web.xml arquivo -
<?xml version = "1.0" Encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id = "WebApp_ID" version = "3.0">
<display-name>Struts 2</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
Agora clique com o botão direito no nome do projeto e clique Export > WAR Filepara criar um arquivo de guerra. Em seguida, implante esse WAR no diretório webapps do Tomcat. Finalmente, inicie o servidor Tomcat e tente acessar o URLhttp://localhost:8080/HelloWorldStruts2/upload.jsp. Isso produzirá a seguinte tela -
Agora selecione um arquivo "Contacts.txt" usando o botão Browse e clique no botão upload que fará o upload do arquivo em seu servidor e você verá a próxima página. Você pode verificar se o arquivo carregado deve ser salvo em C: \ apache-tomcat-6.0.33 \ work.
Observe que o FileUpload Interceptor exclui o arquivo carregado automaticamente, então você terá que salvar o arquivo carregado programaticamente em algum local antes de ser excluído.
Mensagens de erro
O interceptor fileUplaod usa várias chaves de mensagem de erro padrão -
Sr. Não | Chave e descrição da mensagem de erro |
---|---|
1 | struts.messages.error.uploading Um erro geral que ocorre quando o arquivo não pode ser carregado. |
2 | struts.messages.error.file.too.large Ocorre quando o arquivo carregado é muito grande, conforme especificado por maximumSize. |
3 | struts.messages.error.content.type.not.allowed Ocorre quando o arquivo carregado não corresponde aos tipos de conteúdo especificados especificados. |
Você pode substituir o texto dessas mensagens em WebContent/WEB-INF/classes/messages.properties arquivos de recursos.