Simulieren Sie das Hochladen einer einzelnen Datei auf zwei Arten. Der Effekt ist wie folgt
Die Entwicklungsschritte sind wie folgt:
1. Erstellen Sie ein neues Webprojekt und importieren Sie die für Struts2-Upload-Dateien erforderlichen JAR-Dateien, wie unten gezeigt
Verzeichnisstruktur
2. Neue Aktion erstellen
erster Weg
Kopieren Sie den Codecode wie folgt:
Paket com.ljq.action;
java.io.File importieren;
import org.apache.commons.io.FileUtils;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
@SuppressWarnings("serial")
Die öffentliche Klasse UploadAction erweitert ActionSupport{
privates Dateibild; //hochgeladene Datei
private String imageFileName; //Dateiname
private String imageContentType; //Dateityp
public Stringexecute() löst eine Ausnahme aus {
String realpath = ServletActionContext.getServletContext().getRealPath("/images");
//D:/apache-tomcat-6.0.18/webapps/struts2_upload/images
System.out.println("realpath: "+realpath);
if (image != null) {
Datei savefile = new File(new File(realpath), imageFileName);
if (!savefile.getParentFile().exists())
savefile.getParentFile().mkdirs();
FileUtils.copyFile(image, savefile);
ActionContext.getContext().put("message", "Datei erfolgreich hochgeladen");
}
„Erfolg“ zurückgeben;
}
öffentliche Datei getImage() {
Bild zurückgeben;
}
public void setImage(Dateibild) {
this.image = Bild;
}
öffentlicher String getImageFileName() {
return imageFileName;
}
public void setImageFileName(String imageFileName) {
this.imageFileName = imageFileName;
}
öffentlicher String getImageContentType() {
return imageContentType;
}
public void setImageContentType(String imageContentType) {
this.imageContentType = imageContentType;
}
}
Zweiter Weg
Kopieren Sie den Codecode wie folgt:
Paket com.ljq.action;
java.io.File importieren;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionSupport;
@SuppressWarnings("serial")
Die öffentliche Klasse UploadAction2 erweitert ActionSupport {
//Kapseln Sie die Attribute der hochgeladenen Dateidomäne
privates Dateibild;
//Kapseln Sie die Attribute des hochgeladenen Dateityps
private String imageContentType;
//Kapseln Sie die Attribute des hochgeladenen Dateinamens
private String imageFileName;
//Akzeptiere Abhängigkeitsinjektionseigenschaften
privater String savePath;
@Override
public Stringexecute() {
FileOutputStream fos = null;
FileInputStream fis = null;
versuchen {
//Dateiausgabestream erstellen
System.out.println(getSavePath());
fos = new FileOutputStream(getSavePath() + "//" + getImageFileName());
//Erstelle einen Datei-Upload-Stream
fis = new FileInputStream(getImage());
byte[] buffer = neues byte[1024];
int len = 0;
while ((len = fis.read(buffer)) > 0) {
fos.write(buffer, 0, len);
}
} Catch (Ausnahme e) {
System.out.println("Datei-Upload fehlgeschlagen");
e.printStackTrace();
} Endlich {
close(fos, fis);
}
Rückkehr ERFOLGREICH;
}
/**
* Kehren Sie zum Speicherort der hochgeladenen Datei zurück
*
* @zurückkehren
*/
public String getSavePath() löst eine Ausnahme aus{
return ServletActionContext.getServletContext().getRealPath(savePath);
}
public void setSavePath(String savePath) {
this.savePath = savePath;
}
öffentliche Datei getImage() {
Bild zurückgeben;
}
public void setImage(Dateibild) {
this.image = Bild;
}
öffentlicher String getImageContentType() {
return imageContentType;
}
public void setImageContentType(String imageContentType) {
this.imageContentType = imageContentType;
}
öffentlicher String getImageFileName() {
return imageFileName;
}
public void setImageFileName(String imageFileName) {
this.imageFileName = imageFileName;
}
private void close(FileOutputStream fos, FileInputStream fis) {
if (fis != null) {
versuchen {
fis.close();
} Catch (IOException e) {
System.out.println("FileInputStream konnte nicht geschlossen werden");
e.printStackTrace();
}
}
if (fos != null) {
versuchen {
fos.close();
} Catch (IOException e) {
System.out.println("FileOutputStream konnte nicht geschlossen werden");
e.printStackTrace();
}
}
}
}
struts.xml-Konfigurationsdatei
Kopieren Sie den Codecode wie folgt:
<?xml version="1.0"kodierung="UTF-8" ?>
<!DOCTYPE steht für PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
„http://struts.apache.org/dtds/struts-2.0.dtd“>
<Streben>
<!-- Dieses Attribut gibt das Anforderungssuffix an, das von Struts2 verarbeitet werden muss. Der Standardwert dieses Attributs ist action, dh alle Anforderungen, die mit *.action übereinstimmen, werden von Struts2 verarbeitet.
Wenn der Benutzer mehrere Anforderungssuffixe angeben muss, trennen Sie die mehreren Suffixe durch Kommas (,). ->
<constant name="struts.action.extension" value="do" />
<!-- Legen Sie fest, ob der Browser statischen Inhalt zwischenspeichert. Der Standardwert ist „true“ (wird in der Produktionsumgebung verwendet). Deaktivieren Sie ihn am besten während der Entwicklungsphase
<constant name="struts.serve.static.browserCache" value="false" />
<!-- Wenn die Struts-Konfigurationsdatei geändert wird und das System die Datei automatisch neu lädt, ist der Standardwert false (wird in der Produktionsumgebung verwendet). Es ist am besten, ihn während der Entwicklungsphase zu aktivieren ->
<constant name="struts.configuration.xml.reload" value="true" />
<!-- Wird im Entwicklungsmodus verwendet, damit detailliertere Fehlermeldungen ausgedruckt werden können -->
<constant name="struts.devMode" value="true" />
<!--Standardansichtsthema-->
<constant name="struts.ui.theme" value="simple" />
<!--<constant name="struts.objectFactory" value="spring" />-->
<!--Lösung für verstümmelte Codes-->
<constant name="struts.i18n.encoding" value="UTF-8" />
<!-- Geben Sie die maximal zulässige Anzahl von Bytes für hochgeladene Dateien an. Der Standardwert ist 2097152(2M) ->
<konstanter Name="struts.multipart.maxSize" value="10701096"/>
<!-- Legen Sie den temporären Ordner für hochgeladene Dateien fest, standardmäßig wird javax.servlet.context.tempdir verwendet -->
<constant name="struts.multipart.saveDir " value="d:/tmp" />
<Paketname="upload" namespace="/upload" erweitert="struts-default">
<action name="*_upload" method="{1}">
<result name="success">/WEB-INF/page/message.jsp</result>
</action>
</Paket>
<Paketname="upload2" erweitert="struts-default">
<Aktionsname="upload2" method="execute">
<!-- Legen Sie den Attributwert von savePath dynamisch fest -->
<param name="savePath">/images</param>
<result name="success">/WEB-INF/page/message.jsp</result>
<result name="input">/upload/upload.jsp</result>
<interceptor-ref name="fileUpload">
<!-- Dateifilterung -->
<param name="allowedTypes">image/bmp,image/png,image/gif,image/jpeg</param>
<!-- Dateigröße, in Bytes -->
<param name="maximumSize">1025956</param>
</interceptor-ref>
<!-- Der Standard-Interceptor muss nach fileUpload platziert werden, sonst ist er ungültig -->
<interceptor-ref name="defaultStack" />
</action>
</Paket>
</struts>
Formularseite hochladen
Kopieren Sie den Codecode wie folgt:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<Kopf>
<title>Datei hochladen</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
</head>
<Körper>
<!-- ${pageContext.request.contextPath}/upload/execute_upload.do -->
<!-- ${pageContext.request.contextPath}/upload2/upload2.do -->
<form action="${pageContext.request.contextPath}/upload2/upload2.do"
enctype="multipart/form-data" method="post">
Datei:<Eingabetyp="file" name="image">
<input type="submit" value="Upload" />
</form>
<br/>
<s:fielderror />
</body>
</html>
Ergebnisseite anzeigen
Kopieren Sie den Codecode wie folgt:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<Kopf>
<title>Hochladen erfolgreich</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
</head>
<Körper>
Hochladen erfolgreich!
<br/><br/>
<!-- ${pageContext.request.contextPath} Tomcat-Bereitstellungspfad,
Zum Beispiel: D:/apache-tomcat-6.0.18/webapps/struts2_upload/ -->
<img src="${pageContext.request.contextPath}/<s:property value="'images/'+imageFileName"/>">
<s:debug></s:debug>
</body>
</html>