附件上传

1.打上附件上传界面js

	//打开上传附件界面
	function selfUploadFile()
	{
		var url = "<%=request.getContextPath()%>/costech/mw/attachment/attachment.jsp?referenceID=<%=oFile.getFILEID()%>";
		var rtn = window.showModalDialog(url,document,'dialogWidth:650px;dialogHeight:500px;dialogLeft:600px;dialogTop:250px');
	}

2.附件上传界面jsp及js:attachment.jsp

<%@page import="com.costech.common.util.StringUtility" %>
<%@page contentType="text/html;charset=UTF-8" %>
<html>
<head>
<title>上传文件</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<%
request.setCharacterEncoding("utf-8");
String referenceID = StringUtility.toStringValue(request.getParameter("referenceID"),"");
%>
</head>
<body>
    <style type="text/css">
        .fu_list
        {
            width: 600px;
            background: #ebebeb;
            font-size: 12px;
        }
        .fu_list td
        {
            padding: 5px;
            line-height: 20px;
            background-color: #fff;
        }
        .fu_list table
        {
            width: 100%;
            border: 1px solid #ebebeb;
        }
        .fu_list thead td
        {
            background-color: #f4f4f4;
        }
        .fu_list b
        {
            font-size: 14px;
        }
        /*file容器样式*/
        a.files
        {
            width: 90px;
            height: 30px;
            overflow: hidden;
            display: block;
            border: 1px solid #BEBEBE;
            background: url(<%=request.getContextPath()%>/image/common/uploadfile.gif) left top no-repeat;
            text-decoration: none;
        }
        a.files:hover
        {
            background-color: #FFFFEE;
            background-position: 0 -30px;
        }
        /*file设为透明,并覆盖整个触发面*/
        a.files input
        {
            margin-left: -350px;
            font-size: 30px;
            cursor: pointer;
            filter: alpha(opacity=0);
            opacity: 0;
        }
        /*取消点击时的虚线框*/
        a.files, a.files input
        {
            outline: none; /*ff*/
            hide-focus: expression(this.hideFocus=true); /*ie*/
        }
    </style>
    <form id="uploadForm" action="<%=request.getContextPath()%>/scripts/common/attachment/uploadfilesext.jsp?referenceID=<%=referenceID%>">
    <table border="0" cellspacing="1" class="fu_list">
        <thead>
            <tr>
                <td colspan="2">
                    <b>上传文件</b>
                </td>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td align="right" width="15%" style="line-height: 35px;">
                    添加文件1:
                </td>
                <td>
                    <a href="javascript:void(0);" class="files" id="idFile"></a>
                    <img id="idProcess" style="display: none;" src="<%=request.getContextPath()%>/image/common/uploadfile.gif" />
                </td>
            </tr>
            <tr>
                <td colspan="2">
                    <table border="0" cellspacing="0">
                        <thead>
                            <tr>
                                <td>
                                    文件路径
                                </td>
                                <td width="100">
                                </td>
                            </tr>
                        </thead>
                        <tbody id="idFileList">
                        </tbody>
                    </table>
                </td>
            </tr>
            <tr>
                <td colspan="2" style="color: gray">
                    温馨提示:最多可同时上传 <b id="idLimit"></b>个文件,只允许上传 <b id="idExt"></b>文件。
                </td>
            </tr>
            <tr>
                <td colspan="2" align="center" id="idMsg">
                    <input type="button" value="开始上传" id="idBtnupload" disabled="disabled" />
                       
                    <input type="button" value="全部取消" id="idBtndel" disabled="disabled" />
                </td>
            </tr>
        </tbody>
    </table>
    </form>
    
<script type="text/javascript" language="javascript">
    var isIE = (document.all) ? true : false;
    var $ = function (id) {
        return "string" == typeof id ? document.getElementById(id) : id;
    };
    var Class = {
        create: function () {
            return function () {
                this.initialize.apply(this, arguments);
            }
        }
    }
    var Extend = function (destination, source) {
        for (var property in source) {
            destination[property] = source[property];
        }
    }
    var Bind = function (object, fun) {
        return function () {
            return fun.apply(object, arguments);
        }
    }
    var Each = function (list, fun) {
        for (var i = 0, len = list.length; i < len; i++) { fun(list[i], i); }
    };
 
    //文件上传类
    var FileUpload = Class.create();
    FileUpload.prototype = {
        //表单对象,文件控件存放空间
        initialize: function (form, folder, options) {
            this.Form = $(form); //表单
            this.Folder = $(folder); //文件控件存放空间
            this.Files = []; //文件集合
 
            this.SetOptions(options);
 
            this.FileName = this.options.FileName;
            this._FrameName = this.options.FrameName;
            this.Limit = this.options.Limit;
            this.Distinct = !!this.options.Distinct;
            this.ExtIn = this.options.ExtIn;
            this.ExtOut = this.options.ExtOut;
 
            this.onIniFile = this.options.onIniFile;
            this.onEmpty = this.options.onEmpty;
            this.onNotExtIn = this.options.onNotExtIn;
            this.onExtOut = this.options.onExtOut;
            this.onLimite = this.options.onLimite;
            this.onSame = this.options.onSame;
            this.onFail = this.options.onFail;
            this.onIni = this.options.onIni;
 
            if (!this._FrameName) {
                //为每个实例创建不同的iframe
                this._FrameName = "uploadFrame_" + Math.floor(Math.random() * 1000);
                //ie不能修改iframe的name
                var oFrame = isIE ? document.createElement("<iframe name=\"" + this._FrameName + "\">") : document.createElement("iframe");
                //为ff设置name
                oFrame.name = this._FrameName;
                oFrame.style.display = "none";
                //在ie文档未加载完用appendChild会报错
                document.body.insertBefore(oFrame, document.body.childNodes[0]);
            }
 
            //设置form属性,关键是target要指向iframe
            this.Form.target = this._FrameName;
            this.Form.method = "post";
            //注意ie的form没有enctype属性,要用encoding
            this.Form.encoding = "multipart/form-data";
 
            //整理一次
            this.Ini();
        },
        //设置默认属性
        SetOptions: function (options) {
            this.options = {//默认值
                FileName: "filename", //文件上传控件的name,配合后台使用
                FrameName: "", //iframe的name,要自定义iframe的话这里设置name
                onIniFile: function () { }, //整理文件时执行(其中参数是file对象)
                onEmpty: function () { }, //文件空值时执行
                Limit: 0, //文件数限制,0为不限制
                onLimite: function () { }, //超过文件数限制时执行
                Distinct: true, //是否不允许相同文件
                onSame: function () { }, //有相同文件时执行
                ExtIn: [], //允许后缀名
                onNotExtIn: function () { }, //不是允许后缀名时执行
                ExtOut: [], //禁止后缀名,当设置了ExtIn则ExtOut无效
                onExtOut: function () { }, //是禁止后缀名时执行
                onFail: function () { }, //文件不通过检测时执行(其中参数是file对象)
                onIni: function () { } //重置时执行
            };
            Extend(this.options, options || {});
        },
        //整理空间
        Ini: function () {
            //整理文件集合
            this.Files = [];
            //整理文件空间,把有值的file放入文件集合
            Each(this.Folder.getElementsByTagName("input"), Bind(this, function (o) {
                if (o.type == "file") { o.value && this.Files.push(o); this.onIniFile(o); }
            }))
            //插入一个新的file
            var file = document.createElement("input");
            file.name = this.FileName; file.type = "file"; file.onchange = Bind(this, function () { this.Check(file); this.Ini(); });
            this.Folder.appendChild(file);
            //执行附加程序
            this.onIni();
        },
        //检测file对象
        Check: function (file) {
            //检测变量
            var bCheck = true;
            //空值、文件数限制、后缀名、相同文件检测
            if (!file.value) {
                bCheck = false; this.onEmpty();
            } else if (this.Limit && this.Files.length >= this.Limit) {
                bCheck = false; this.onLimite();
            } else if (!!this.ExtIn.length && !RegExp("\.(" + this.ExtIn.join("|") + ")$", "i").test(file.value)) {
                //检测是否允许后缀名
                bCheck = false; this.onNotExtIn();
            } else if (!!this.ExtOut.length && RegExp("\.(" + this.ExtOut.join("|") + ")$", "i").test(file.value)) {
                //检测是否禁止后缀名
                bCheck = false; this.onExtOut();
            } else if (!!this.Distinct) {
                Each(this.Files, function (o) { if (o.value == file.value) { bCheck = false; } })
                if (!bCheck) { this.onSame(); }
            }
            //没有通过检测
            !bCheck && this.onFail(file);
        },
        //删除指定file
        Delete: function (file) {
            //移除指定file
            this.Folder.removeChild(file); this.Ini();
        },
        //删除全部file
        Clear: function () {
            //清空文件空间
            Each(this.Files, Bind(this, function (o) { this.Folder.removeChild(o); })); this.Ini();
        }
    }
 
    var fu = new FileUpload("uploadForm", "idFile", { Limit: 3, ExtIn: ["jpg", "gif","sql"],
        onIniFile: function (file) { file.value ? file.style.display = "none" : this.Folder.removeChild(file); },
        onEmpty: function () { alert("请选择一个文件"); },
        onLimite: function () { alert("超过上传限制"); },
        onSame: function () { alert("已经有相同文件"); },
        onNotExtIn: function () { alert("只允许上传" + this.ExtIn.join(",") + "文件"); },
        onFail: function (file) { this.Folder.removeChild(file); },
        onIni: function () {
            //显示文件列表
            var arrRows = [];
            if (this.Files.length) {
                var oThis = this;
                Each(this.Files, function (o) {
                    var a = document.createElement("a"); a.innerHTML = "取消"; a.href = "javascript:void(0);";
                    a.onclick = function () { oThis.Delete(o); return false; };
                    arrRows.push([o.value, a]);
                });
            } else { arrRows.push(["<font color='gray'>没有添加文件</font>", " "]); }
            AddList(arrRows);
            //设置按钮
            $("idBtnupload").disabled = $("idBtndel").disabled = this.Files.length <= 0;
        }
    });
 
    $("idBtnupload").onclick = function () {
        //显示文件列表
        var arrRows = [];
        Each(fu.Files, function (o) { arrRows.push([o.value, " "]); });
        AddList(arrRows);
 
        fu.Folder.style.display = "none";
        $("idProcess").style.display = "";
        $("idMsg").innerHTML = "正在添加文件到您的网盘中,请稍候……<br />有可能因为网络问题,出现程序长时间无响应,请点击“<a href='?'><font color='red'>取消</font></a>”重新上传文件";
 
        fu.Form.submit();
    }
 
    //用来添加文件列表的函数
    function AddList(rows) {
        //根据数组来添加列表
        var FileList = $("idFileList"), oFragment = document.createDocumentFragment();
        //用文档碎片保存列表
        Each(rows, function (cells) {
            var row = document.createElement("tr");
            Each(cells, function (o) {
                var cell = document.createElement("td");
                if (typeof o == "string") { cell.innerHTML = o; } else { cell.appendChild(o); }
                row.appendChild(cell);
            });
            oFragment.appendChild(row);
        })
        //ie的table不支持innerHTML所以这样清空table
        while (FileList.hasChildNodes()) { FileList.removeChild(FileList.firstChild); }
        FileList.appendChild(oFragment);
    }
    $("idLimit").innerHTML = fu.Limit;
    $("idExt").innerHTML = fu.ExtIn.join(",");
    $("idBtndel").onclick = function () { fu.Clear(); }
    //在后台通过window.parent来访问主页面的函数
    function Finish(msg) { alert(msg); window.close(); }
</script>
    
</body>
</html>

注意点:

1.1 <form id="uploadForm" action="<%=request.getContextPath()%>/scripts/common/attachment/uploadfilesext.jsp?referenceID=<%=referenceID%>">

文件提交后台保存处理类;

1.2 FileName: "filename", //文件上传控件的name,配合后台使用 不设置此行,后台接收不到文件。原因末明。


3.后台保存文件处理类:uploadfilesext.jsp

<%@page contentType="text/html;charset=utf-8"%>
<%@ page language="java" import="java.util.List"%>
<%@ page language="java" import="java.util.Map"%>
<%@ page language="java" import="org.apache.commons.fileupload.*"%>
<%@ page language="java" import="org.apache.commons.fileupload.disk.*"%>
<%@ page language="java" import="org.apache.commons.fileupload.servlet.*"%>
<%@page import="com.costech.common.util.StringUtility"%>
<%@page import="com.costech.common.helper.AttachmentHelper" %>
<%@page import="com.costech.common.bean.Attachment" %>
<%@page import="com.costech.common.service.ICommonService"%>
<%@page import="com.costech.common.helper.ServiceHelper"%>
<%@page import="com.costech.common.constants.CommonConstants"%>
<%@page import="com.costech.common.bean.VObean"%>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<%
request.setCharacterEncoding("utf-8");
String referenceID = StringUtility.toStringValue(request.getParameter("referenceID"),"");

//wangjj 2013-08-01  根据ReferenceID获取了之前图片的fileID,得以将之前的图片删除; 
ICommonService gd = (ICommonService)ServiceHelper.getService(CommonConstants.COMMON_SERVICE);
String sql = "select FileID from XT_Document where ReferenceID='" + referenceID + "'";
String FileID = gd.getNameListBySql(sql,"FileID",";");
// coding end 

String fileType = StringUtility.toStringValue(request.getParameter("fileType"),"");
DiskFileItemFactory factory = new DiskFileItemFactory();
//设置上传工厂的限制
factory.setSizeThreshold(1024 * 1024  * 20);
//factory.setRepository(new File(request.getRealPath("/")));
//创建一个上传文件的ServletFileUpload对象
ServletFileUpload upload = new ServletFileUpload(factory);

//设置最大的上传限制
upload.setSizeMax(1024 * 1024 * 20);

//处理HTTP请求,items是所有的表单项

List items = upload.parseRequest(request);
AttachmentHelper ga = new AttachmentHelper();
Attachment attachment; 
String filename;
String title;
long filesize;
String contenttype;
byte[] fileContent = null;
for(int i =0; i < items.size(); i ++){
	//System.out.println("items:    " + ((FileItem)items.get(i)).getName());
	FileItem fileItem=(FileItem)items.get(i);
	
	filename=fileItem.getName();
	if(filename!=null && !filename.equals(""))
	{
	filesize=fileItem.getSize();
	fileContent=fileItem.get();	
	filename=filename.substring(filename.lastIndexOf("\\")+1);
		//System.out.println("filename----------->"+filename);
		contenttype=fileItem.getContentType();
		
		
		try
		{   
				//只是简单保存
				//myFile.saveAs(dir+"/"+filename);
				attachment =  new Attachment();
	 			attachment.setFileName(filename);
				attachment.setFileContentType(contenttype);
				attachment.setFileSize(Integer.parseInt(new String(Long.toString(filesize))));
			
				attachment.setFileContent(fileContent);			
				title=filename.substring(0,filename.lastIndexOf('.'));					
				attachment.setFileTitle(title);
				
				//update by wangjj 2013-9-27
				//fileType為1的時候 是個人手寫簽名
				if(fileType.equals("1")){
					attachment.setFileID(FileID); 
				}
				//wangjj add end
				attachment.setReferenceID(referenceID);
				//System.out.println("---------------===================fileType1234:"+fileType);
				attachment.setFileType(fileType);				
				attachment.setUploader((String)session.getAttribute("userid"));			
				String result = ga.update("xt_document",attachment);
 		}
 		catch(Exception e)
		{
				
		}		
	}
			
	 	  // end if (!myFile.isMissing())
	}// end for 
	String _msg="上传成功";
	out.println("<script>window.parent.Finish('"+_msg+"');</script>");
%>


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值