基於struts2的ajaxfileupload異步上傳插件的使用

實例:
javascript

jsp頁面css

<%@ page language="java" contentType="text/html" pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html">
<title>文件上傳</title>
<link rel="stylesheet"
	href="${pageContext.request.contextPath }/js/AjaxFileUploaderV2.1/ajaxfileupload.css">
<script type="text/javascript"
	src="${pageContext.request.contextPath }/js/AjaxFileUploaderV2.1/jquery.js"></script>
<script type="text/javascript"
	src="${pageContext.request.contextPath }/js/AjaxFileUploaderV2.1/ajaxfileupload.js"></script>
<script type="text/javascript">
	function FormSubmit() {
		var file = $("#file").val();
		if (file == "") {
			alert("請選擇文件");
			return;
		}
		var fileType = file.substring(file.lastIndexOf(".") + 1);
		if (fileType != "docx" && fileType != "doc") {
			alert("上傳文件格式錯誤");
			return;
		}
		var url = "${pageContext.request.contextPath}/struts2_upload.action?nowtime="
				+ new Date().getTime();
		$.ajaxFileUpload({
			url : url,
			secureuri : false,
			fileElementId : "file", //file的id 
			dataType : 'json',//返回值類型 通常設置爲json
			success : function(data, status) {
				alert(data.message);
			}
		});
	}
</script>
</head>
<body>
	<div>
		<form
			action="${pageContext.request.contextPath }/struts2_upload.action"
			method="post" enctype="multipart/form-data">
			<p>
				<label>請選擇上傳文件:</label><input type="file" name="file" id="file">
			</p>
			<p>
				<input type="button" value="提交" onclick="FormSubmit();" />
			</p>
		</form>
	</div>
</body>
</html>

Action代碼html

package org.zsm.learn.struts2.action;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.HashMap;
import java.util.Map;

import org.apache.commons.io.IOUtils;
import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionSupport;

public class FileUploadAction extends ActionSupport {

	private static final long serialVersionUID = -1063647163701747470L;

	// 與上傳文件相關的三個參數
	private File file;
	private String fileFileName;
	private String fileContentType;
	// Action相關參數的設置
	private String savePath;
	private long maximumSize;
	private String allowedTypes;

	// 返回結果
	private Map<String, Object> result;

	public Map<String, Object> getResult() {
		return result;
	}

	public String upload() {
		result = new HashMap<String, Object>();
		// 判斷上傳文件是否符合要求
		if (getFile() == null) {
			result.put("success", false);
			result.put("messages", "上傳文件不能爲空!!!");
		} else if (!validateUploadLength(maximumSize)) {
			result.put("success", false);
			result.put("message", "上傳文件超出了限制!!!");
		} else if (!validateUploadType(allowedTypes)) {
			result.put("success", false);
			result.put("message", "上傳文件類型不符合要求!!!");
		} else {
			// 獲取存儲上傳目錄
			String storageDir = ServletActionContext.getServletContext()
					.getRealPath(savePath);
			// 判斷存儲上傳目錄
			File storageFile = new File(storageDir);
			if (!storageFile.exists()) {
				storageFile.mkdirs();
			}
			// 上傳文件
			File destFile = generateDestFile(storageDir, fileFileName);
			uploadFile(destFile, file);
			result.put("success", true);
			result.put("message", "文件上傳成功!!!");
		}
		return "success";
	}
	
	public String ActionError(){
		result = new HashMap<String, Object>();
		result.put("success", false);
		result.put("messages", "上傳文件超過了限制的大小");
		return "actionError";
	}
	
	public File getFile() {
		return file;
	}

	public void setFile(File file) {
		this.file = file;
	}

	public String getFileFileName() {
		return fileFileName;
	}

	public void setFileFileName(String fileFileName) {
		this.fileFileName = fileFileName;
	}

	public String getFileContentType() {
		return fileContentType;
	}

	public void setFileContentType(String fileContentType) {
		this.fileContentType = fileContentType;
	}

	public File generateDestFile(String destFileDir, String sourceFileName) {
		File destDir = new File(destFileDir);
		if (!destDir.exists()) {
			destDir.mkdirs();
		}
		// 生成規則
		return new File(destDir, sourceFileName);
	}

	public static void uploadFile(File destFile, File sourceFile) {
		InputStream input = null;
		OutputStream output = null;
		try {
			input = new FileInputStream(sourceFile);
			output = new FileOutputStream(destFile);
			IOUtils.copy(input, output);
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		} finally {
			IOUtils.closeQuietly(output);
			IOUtils.closeQuietly(input);
		}
	}

	/**
	 * 判斷是否支持上傳文件的類型
	 * 
	 * @param types
	 * @return
	 */
	public boolean validateUploadType(String types) {
		String[] allowedTypes = null;
		// 獲取文件上傳類型
		String fileType = getFileContentType();
		allowedTypes = types.split(",");
		for (String type : allowedTypes) {
			if (type.equals(fileType)) {
				return true;
			}
		}
		return false;
	}

	public boolean validateUploadLength(long maximumSize) {
		if (getFile().length() > maximumSize) {
			return false;
		}
		return true;
	}

	public String getSavePath() {
		return savePath;
	}

	public void setSavePath(String savePath) {
		this.savePath = savePath;
	}

	public long getMaximumSize() {
		return maximumSize;
	}

	public void setMaximumSize(long maximumSize) {
		this.maximumSize = maximumSize;
	}

	public String getAllowedTypes() {
		return allowedTypes;
	}

	public void setAllowedTypes(String allowedTypes) {
		this.allowedTypes = allowedTypes;
	}
}

struts.xml配置java

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
	"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
	"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
	<!-- <constant name="struts.custom.i18n.resources" value="ApplicationResources" 
		/> -->
	<package name="default" extends="json-default">
	   <action name="struts2_*" class="org.zsm.learn.struts2.action.FileUploadAction"
		method="{1}">
		 <param name="savePath">/upload</param>
		 <param name="maximumSize">1048576</param>
		 <param name="allowedTypes">
			application/vnd.ms-powerpoint,application/msword
		 </param>
		<!-- 注意結合Action觀察struts.xml中result的配置。 contentType參數是必定要有的,
		不然瀏覽器老是提示將返回的JSON結果另存爲文件,不會交給ajaxfileupload處理。這是因 
		爲struts2 JSON Plugin默認的contentType爲application/json,
		而ajaxfileupload則要求爲text/html。 -->
		<result name="success" type="json">
		  <param name="contentType">
			text/html
		  </param>
		  <param name="root">result</param>
		</result>
		<result name="actionError" type="json">
	          <param name="root">result</param>
		  <param name="contentType">
			text/html
		</param>
		</result>
		<result name="input" type="redirect">struts2_ActionError.action</result>
	</action>
	</package>
</struts>
相關文章
相關標籤/搜索