/*******************************************************************************
* 文件名: FileUploadAction.java
* 版本:
* 描述: 一个文件上传,下载的Action,继承于BaseAcion
* 版权所有:
*
* 创建者: 赵志强
* 创建日期: 2005-10-28
* 修改者: 赵志强
* 修改日期: 2005-11-3
* 修改说明: 添加gotoUpload方法,用户通过此方法跳转到upload.vm
******************************************************************************/
package com.css.action;
import java.io.FileInputStream;
import java.io.InputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.BufferedOutputStream;
import java.io.BufferedInputStream;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.List;
import java.util.ArrayList;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.upload.*;
import org.apache.struts.validator.DynaValidatorForm;
import com.css.bean.FileInfoDTO;
import com.css.dao.DAOFactory;
import com.css.dao.FileInfoDAO;
import com.css.exception.BaseException;
import com.css.util.db.DBConfig;
import com.css.bean.UserDTO;
/**
* @author WANG
*
* Java - 代码样式 - 代码模板
*/
public class FileUploadAction extends BaseAction {
public ActionForward fileUpload(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws BaseException {
//将字符统一为gb2312
/*
* String encoding = request.getCharacterEncoding(); if ((encoding !=
* null) && (encoding.equalsIgnoreCase("utf-8"))) {
* //如果没有指定编码,编码格式为gb2312 response.setCon*("text/html; charset=gb2312"); }
*/
//取得DynaValidatorForm的值,通过theFile.get("FileUploadForm")取得上传的文件
DynaValidatorForm fileUploadForm = (DynaValidatorForm) form;
FormFile file = null;
file = (FormFile) fileUploadForm.get("theFile");
String describe = fileUploadForm.getString("describe");
String permit = fileUploadForm.getString("permit");
//设置用户权限不足时出现的错误,用户将跳转到download.vm--FileUpload.do?act=showFile
UserDTO userDTO = getSessionObj(request);
if (userDTO == null) {
this.setSysMessage(request, "login.failAdmin", "btn.readmin",
"FileUpload.do?act=showFile");
return mapping.findForward("error");
}
//获取FormFile的实例fileName中的两个属性
String fileName = file.getFileName();//取得文件名
//测试该文件是不是合法
if(!isValidFile(fileName))
{
this.setSysMessage(request, "upload.badtype", "btn.reupload",
"FileUpload.do?act=gotoUpload");
return mapping.findForward("error");
}
int fileSize = file.getFileSize();//取得文件尺寸
//通过getInputStream()方法取得文件流
BufferedInputStream bis = null;
BufferedOutputStream bos = null;
InputStream is = null;
OutputStream fos = null;
try {
is = (InputStream) file.getInputStream();//把文件读入
bis = new BufferedInputStream(is);
String filePath = getUploadDir();//取当前系统路径
fos = new FileOutputStream(filePath + fileName);//建立一个上传文件的输出流
bos = new BufferedOutputStream(fos);
//System.out.println(filePath + fileName);
//文件最大限额
int fileMaxSize = 10 * 1024 * 1024;
if (fileSize > fileMaxSize) {
//文件大小不能超过fileMaxSize,如果超过,报"上传文件尺寸超过10M"错误;
this.setSysMessage(request, "upload.max", "btn.reupload",
"FileUpload.do?act=gotoUpload");
return mapping.findForward("error");
}
int bytesRead = 0;
byte[] buffer = new byte[5 * 1024];
while ((bytesRead = bis.read(buffer)) != -1) {
bos.write(buffer, 0, bytesRead);//将文件写入服务器
}
}
catch (IOException e) {
//设置文件物理上传出现问题时的出现的错误信息
this.setSysMessage(request, "upload.failed", "btn.reupload",
"FileUpload.do?act=gotoUpload");
return mapping.findForward("error");
}
finally {
if (bos != null) {
try {
bos.close();
}
catch (IOException e) {
System.err.print(e);
}
}
if (bis != null) {
try {
bis.close();
}
catch (IOException e) {
System.err.print(e);
}
}
}
//文件物理上传完成
//将文件信息添加到数据库
//填充FileInfoDTO
FileInfoDTO dto = new FileInfoDTO();
dto.setCheckType("1");
dto.setDescribe(describe);
dto.setFileName(fileName);
dto.setFileSize(String.valueOf(fileSize));
dto.setIsUse("0");
dto.setPermit(permit);
dto.setUserID(userDTO.getUserId());
FileInfoDAO fileinfoDAO = (FileInfoDAO) DAOFactory.getDAOFactory(
DBConfig.getDataBaseName()).getFileInfoDAO();
int result = fileinfoDAO.insert(dto);
//request.setAttribute("dat",file.getFileName());
if (result > 0) {
return mapping.findForward("gotoUpload");
}
else {
//设置文件写入数据库时出现的信息
this.setSysMessage(request, "upload.failed", "btn.reupload",
"FileUpload.do?act=gotoUpload");
return mapping.findForward("error");
}
}
public ActionForward fileDownLoad(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws BaseException {
/*
* 取得文件:文件id+文件路径+文件名+流 文件id=通过formbean取得 文件路径=通过取得配置文件的方法得到
* 文件名称=通过数据库得到 流=io
*/
//取得文件路径,也就是保存文件的文件夹名称
String fileID = null;//文件id
String filePath = null;//方法取得路径
String fileName = null;//名称
String permit = null; //权限,用来作身份验证
BufferedInputStream bis = null;
BufferedOutputStream bos = null;
OutputStream fos = null;
InputStream fis = null;
// DynaValidatorForm fileUploadForm = (DynaValidatorForm) form;
// fileID = fileUploadForm.getString("fileID");//得到文件id
fileID = request.getParameter("fileID");
filePath = getUploadDir();
FileInfoDAO fileinfoDAO = (FileInfoDAO) DAOFactory.getDAOFactory(
DBConfig.getDataBaseName()).getFileInfoDAO();
FileInfoDTO fileInfoDTO = fileinfoDAO.findByPK(fileID);
if(fileInfoDTO == null)
{
this.setSysMessage(request, "download.failed", "btn.redownload",
"FileUpload.do?act=showFile");
return mapping.findForward("error");
}
fileName = fileInfoDTO.getFileName();
permit = fileInfoDTO.getPermit();
//身份验证
UserDTO userDTO = this.getSessionObj(request);
if(userDTO == null)
{
this.setSysMessage(request, "login.failAdmin", "btn.redownload",
"FileUpload.do?act=showFile");
return mapping.findForward("error");
}
else if(!userDTO.getUserType().equals(fileInfoDTO.getPermit()))
{
this.setSysMessage(request, "login.failAdmin", "btn.redownload",
"FileUpload.do?act=showFile");
return mapping.findForward("error");
}
if (fileName == null) {
//设置查找数据时出现的错误信息
this.setSysMessage(request, "download.failed", "btn.redownload",
"FileUpload.do?act=showFile");
return mapping.findForward("error");
}
try {
response.setContentType(this.getContentType(fileName));
response.setHeader("Content-disposition", "attachment;filename="
+ URLEncoder.encode(fileName, "utf-8"));
fis = new FileInputStream(filePath + fileName);
bis = new BufferedInputStream(fis);
fos = response.getOutputStream();
bos = new BufferedOutputStream(fos);
int bytesRead = 0;
byte[] buffer = new byte[5 * 1024];
while ((bytesRead = bis.read(buffer)) != -1) {
bos.write(buffer, 0, bytesRead);//将文件发送到客户端
}
}
catch (IOException e) {
// response.setContentType("text/html");
response.reset();
//设置文件物理下载时出现的错误信息
this.setSysMessage(request, "download.failed", "btn.reupload",
"FileUpload.do?act=showFile");
return mapping.findForward("error");
}
finally {
try {
if (fos != null) {
fos.close();
}
if (bos != null) {
bos.close();
}
if (fis != null) {
fis.close();
}
if (bis != null) {
bis.close();
}
}
catch (IOException e) {
System.err.print(e);
}
}
return null;
}
public ActionForward showFile(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws BaseException {
/*
* 用户下载的方法, 用户可以看到和下载和自己权限一样的文件和所有游客权限的文件
*/
UserDTO userDTO = getSessionObj(request);
boolean isLogin = true;
boolean isCheck = false;
String userType = null;
if (userDTO == null) {
isLogin = false;
}
else {
if (userDTO.getIsCheck().equals("1")) {
isCheck = true;
}
}
/*
* 获取权限后, 连接数据库, 查找权限为permit,以及4(游客权限)的所有权限, 并生成List对象通过request发送给客户.
*/
//连接数据库
FileInfoDAO fileinfoDAO = (FileInfoDAO) DAOFactory.getDAOFactory(
DBConfig.getDataBaseName()).getFileInfoDAO();
//查找并将数据保存在List对象中.
List list = new ArrayList();
//从FILEINFO表和USERS表中查找需要的数据存放在每一个FileInfoDTO中.
//判断用户的权限:isCheck=ture=审核人员,isLogin=内部用户或者外部用户,客户。其他为游客。
if (isCheck) {
list = fileinfoDAO.findAll();
}
else {
if(isLogin)
{
userType = userDTO.getUserType();
list = fileinfoDAO.findAll(userType, isLogin);
}
else
{
userType = "4";
list = fileinfoDAO.findAll(userType, isLogin);
}
}
//将数据保存在request中
request.setAttribute("fileList", list);
request.setAttribute("userDTO", userDTO);
return mapping.findForward("fileDownload");
}
public ActionForward gotoUpload(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws BaseException {
//用户通过此方法跳转到upload.vm
UserDTO userDTO = getSessionObj(request);
if (userDTO == null) {
//设置用户权限不足时出现的错误,用户将跳转到download.vm--FileUpload.do?act=showFile
this.setSysMessage(request, "login.failAdmin", "btn.redownload",
"FileUpload.do?act=showFile");
return mapping.findForward("error");
}
return mapping.findForward("fileUpload");
}
private boolean isValidFile(String fileName) {
String[] validFiles = { "txt", "gif", "jpg", "jpeg", "jpe", "zip",
"rar", "doc", "ppt", "xls", "html", "htm", "tif", "tiff", "pdf" };
boolean ret = false;
for (int i = 0; i < validFiles.length; i++) {
if (fileName.toLowerCase().endsWith(validFiles[i])) {
ret = true;
break;
}
}
return ret;
}
private String getContentType(String fileName) {
String fileNameTmp = fileName.toLowerCase();
String ret = "";
if (fileNameTmp.endsWith("txt")) {
ret = "text/plain";
}
if (fileNameTmp.endsWith("gif")) {
ret = "image/gif";
}
if (fileNameTmp.endsWith("jpg")) {
ret = "image/jpeg";
}
if (fileNameTmp.endsWith("jpeg")) {
ret = "image/jpeg";
}
if (fileNameTmp.endsWith("jpe")) {
ret = "image/jpeg";
}
if (fileNameTmp.endsWith("zip")) {
ret = "application/zip";
}
if (fileNameTmp.endsWith("rar")) {
ret = "application/rar";
}
if (fileNameTmp.endsWith("doc")) {
ret = "application/msword";
}
if (fileNameTmp.endsWith("ppt")) {
ret = "application/vnd.ms-powerpoint";
}
if (fileNameTmp.endsWith("xls")) {
ret = "application/vnd.ms-excel";
}
if (fileNameTmp.endsWith("html")) {
ret = "text/html";
}
if (fileNameTmp.endsWith("htm")) {
ret = "text/html";
}
if (fileNameTmp.endsWith("tif")) {
ret = "image/tiff";
}
if (fileNameTmp.endsWith("tiff")) {
ret = "image/tiff";
}
if (fileNameTmp.endsWith("pdf")) {
ret = "application/pdf";
}
return ret;
}
}