स्ट्रट्स 2 - फाइल अपलोड
स्ट्रट्स 2 फ्रेमवर्क "HTML में फ़ॉर्म-आधारित फ़ाइल अपलोड" का उपयोग करके फ़ाइल को संसाधित करने के लिए अंतर्निहित समर्थन प्रदान करता है। जब कोई फ़ाइल अपलोड की जाती है, तो इसे आम तौर पर एक अस्थायी निर्देशिका में संग्रहीत किया जाता है और डेटा खो जाने के लिए उन्हें सुनिश्चित करने के लिए आपकी कार्रवाई कक्षा द्वारा स्थायी निर्देशिका में संसाधित या स्थानांतरित किया जाना चाहिए।
Note - सर्वर में एक सुरक्षा नीति हो सकती है जो आपको अस्थायी निर्देशिका के अलावा निर्देशिकाओं और आपके वेब एप्लिकेशन से संबंधित निर्देशिकाओं को लिखने से रोकती है।
स्ट्रट्स में फ़ाइल अपलोडिंग एक पूर्व-परिभाषित इंटरसेप्टर के माध्यम से संभव है जिसे कहा जाता है FileUpload इंटरसेप्टर जो org.apache.struts2.interceptor.FileUploadInterceptor वर्ग के माध्यम से उपलब्ध है और इसमें शामिल हैdefaultStack। फिर भी आप विभिन्न स्ट्रेटर्स सेट करने के लिए अपने struts.xml में उपयोग कर सकते हैं जैसा कि हम नीचे देखेंगे।
व्यू फाइल्स बनाएं
आइए हम अपना दृश्य बनाना शुरू करें, जिसे चयनित फ़ाइल को ब्राउज़ करने और अपलोड करने की आवश्यकता होगी। तो आइए हम एक बनाते हैंindex.jsp सादे HTML अपलोड फॉर्म के साथ जो उपयोगकर्ता को फ़ाइल अपलोड करने की अनुमति देता है -
<%@ 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>
उपरोक्त उदाहरण में ध्यान देने योग्य कुछ बिंदु हैं। सबसे पहले, फॉर्म का एनकाइप सेट किया जाता हैmultipart/form-data। इसे सेट किया जाना चाहिए ताकि फ़ाइल अपलोड इंटरसेप्टर द्वारा फ़ाइल अपलोड सफलतापूर्वक संभाला जाए। अगला बिंदु नोटिंग फॉर्म की क्रिया विधि हैupload और फ़ाइल अपलोड फ़ील्ड का नाम - जो है myFile। हमें एक्शन विधि और स्ट्रट्स कॉन्फ़िगरेशन बनाने के लिए इस जानकारी की आवश्यकता है।
इसके बाद, एक सरल जेएसपी फाइल बनाते हैं success.jsp हमारे फ़ाइल अपलोड के परिणाम को प्रदर्शित करने के मामले में यह सफल हो जाता है।
<%@ 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>
इसके बाद रिजल्ट फाइल होगी error.jsp यदि फ़ाइल अपलोड करने में कुछ त्रुटि है -
<%@ 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>
एक्शन क्लास बनाएं
इसके बाद, 'Java' नामक एक जावा क्लास बनाते हैं uploadFile.java जो फ़ाइल को अपलोड करने और सुरक्षित स्थान पर उस फ़ाइल को संग्रहीत करने का ध्यान रखेगा -
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;
}
}
uploadFile.javaएक बहुत ही सरल वर्ग है। ध्यान देने वाली महत्वपूर्ण बात यह है कि पैरामीटर्स इंटरसेप्टर के साथ फाइलअप लोडर इंटरसेप्टर हमारे लिए सभी भारी लिफ्टिंग करता है।
FileUpload इंटरसेप्टर डिफ़ॉल्ट रूप से आपके लिए तीन पैरामीटर उपलब्ध कराता है। उन्हें निम्नलिखित पैटर्न में नामित किया गया है -
[your file name parameter] - यह वास्तविक फाइल है जिसे उपयोगकर्ता ने अपलोड किया है। इस उदाहरण में यह "myFile" होगा
[your file name parameter]ContentType- यह उस फाइल का कंटेंट टाइप है जिसे अपलोड किया गया था। इस उदाहरण में यह "myFileContentType" होगा
[your file name parameter]FileName- यह उस फ़ाइल का नाम है जिसे अपलोड किया गया था। इस उदाहरण में यह "myFileFileName" होगा
स्ट्रट्स इंटरसेप्टर के लिए धन्यवाद, तीन पैरामीटर हमारे लिए उपलब्ध हैं। हमें बस इतना करना है कि हमारे एक्शन क्लास में सही नामों के साथ तीन पैरामीटर बनाएं और स्वचालित रूप से ये चर हमारे लिए ऑटो वायर्ड हैं। इसलिए, उपरोक्त उदाहरण में, हमारे पास तीन पैरामीटर और एक एक्शन विधि है जो बस "सफलता" लौटाती है अगर सबकुछ ठीक हो जाता है अन्यथा यह "त्रुटि" देता है।
कॉन्फ़िगरेशन फ़ाइलें
निम्नलिखित Struts2 कॉन्फ़िगरेशन गुण हैं जो फ़ाइल अपलोडिंग प्रक्रिया को नियंत्रित करते हैं -
अनु क्रमांक | गुण और विवरण |
---|---|
1 | struts.multipart.maxSize फ़ाइल अपलोड के रूप में स्वीकार की जाने वाली फ़ाइल का अधिकतम आकार (बाइट्स)। डिफ़ॉल्ट 250M है। |
2 | struts.multipart.parser पुस्तकालय मल्टीपार्ट फॉर्म को अपलोड करता था। डिफ़ॉल्ट रूप से हैjakarta |
3 | struts.multipart.saveDir अस्थायी फ़ाइल को संग्रहीत करने का स्थान। डिफ़ॉल्ट रूप से javax.servlet.context.tempdir है। |
इनमें से किसी भी सेटिंग को बदलने के लिए, आप उपयोग कर सकते हैं constant आपके एप्लिकेशन struts.xml फ़ाइल में टैग, क्योंकि मैंने अपलोड की जाने वाली फ़ाइल का अधिकतम आकार बदलने के लिए किया था।
हमें अपने struts.xml निम्नानुसार है -
<?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>
जबसे, FileUploadइंटरसेप्टर इंटरसेप्टर के डिफ़ॉल्ट स्टैक का एक हिस्सा है, हमें इसकी खोज को कॉन्फ़िगर करने की आवश्यकता नहीं है। लेकिन, आप <कार्रवाई> के अंदर <इंटरसेप्टर-रेफरी> टैग जोड़ सकते हैं। FileUpload इंटरसेप्टर दो पैरामीटर लेता है(a) maximumSize तथा (b) allowedTypes।
अधिकतम आकार अधिकतम अनुमत अधिकतम फ़ाइल आकार सेट करता है (डिफ़ॉल्ट लगभग 2 एमबी है)। अनुमत पैरामीटर निम्नांकित सामग्री (MIME) प्रकार की एक अल्पविराम से अलग की गई सूची है जो नीचे दी गई है -
<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>
निम्नलिखित की सामग्री है web.xml फ़ाइल -
<?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>
अब प्रोजेक्ट नाम पर राइट क्लिक करें और क्लिक करें Export > WAR Fileएक वार फाइल बनाने के लिए। फिर इस WAR को Tomcat की वेबऐप्स डायरेक्टरी में तैनात करें। अंत में, टॉमकैट सर्वर शुरू करें और URL तक पहुंचने का प्रयास करेंhttp://localhost:8080/HelloWorldStruts2/upload.jsp। यह निम्न स्क्रीन का उत्पादन करेगा -
अब ब्राउज़ बटन का उपयोग करके एक फ़ाइल "कॉन्टेक्ट.टैक्स" चुनें और अपलोड बटन पर क्लिक करें जो आपके सेवा पर फ़ाइल अपलोड करेगा और आपको अगला पृष्ठ देखना चाहिए। आप जांच सकते हैं अपलोड की गई फ़ाइल को C: \ apache-tomcat-6.0.33 \ work में सहेजा जाना चाहिए।
ध्यान दें कि FileUpload Interceptor अपलोड की गई फ़ाइल को स्वचालित रूप से हटा देता है ताकि आपको डिलीट होने से पहले किसी स्थान पर अपलोड की गई फ़ाइल को प्रोग्रामेटिक रूप से सहेजना पड़े।
त्रुटि संदेश
FileUplaod इंटरसेप्टर कई डिफ़ॉल्ट त्रुटि संदेश कुंजी का उपयोग करता है -
अनु क्रमांक | त्रुटि संदेश कुंजी और विवरण |
---|---|
1 | struts.messages.error.uploading एक सामान्य त्रुटि जो तब होती है जब फ़ाइल अपलोड नहीं की जा सकती थी। |
2 | struts.messages.error.file.too.large अधिकतम फ़ाइल द्वारा निर्दिष्ट के रूप में अपलोड की गई फ़ाइल बहुत बड़ी है। |
3 | struts.messages.error.content.type.not.allowed तब होता है जब अपलोड की गई फ़ाइल निर्दिष्ट सामग्री प्रकारों से मेल नहीं खाती। |
आप इन संदेशों के पाठ को ओवरराइड कर सकते हैं WebContent/WEB-INF/classes/messages.properties संसाधन फ़ाइलें।