当前页面: 开发资料首页 → Java 专题 → 用cos进行文件上传
用cos进行文件上传
摘要: 用cos进行文件上传
</td>
</tr>
<tr>
<td width="506" height="35" valign="top" class="ArticleTeitle">
在jsp中实现文件上传,可用的类库很多,比如有著名的jspsmart公司SmartUpload,struts里面也有。我这里说说cos,它是O'Reilly公司的,O'Reilly的图书是很不错的,这个上传的组件也做得很棒,最重要的是,它是open source的。
下载最新的cos包(http://www.servlets.com/cos/index.html),加入到你的classpath中。
编写一个需要上传文件的jsp,为了方便,我就用一个简单的htm文件了,在这个页面中,我们让用户一次可以上传3个文件。
/////////////////////upload.htm////////////////////////////////////
HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<head>
无标题文档
</head>
<body>
<form name="form1" method="post" enctype="multipart/form-data"
<input name="file1" type="file">
<input name="file2" type="file">
<input name="file3" type="file">
<input type="submit" name="Submit" value="上传">
</form >
</body>
在c:\下建一个目录c:\upload,用来存放上传的文件。
写一个jsp或者servlet来实现上传,我这里用一个叫upload.jsp,这样就不用配置web.xml,呵呵,比较懒的说。
////////////////////////////upload.jsp////////////////////////
<%@page import="java.io.*"%>
<%@page import="com.oreilly.servlet.MultipartRequest"%>
<%@page import="com.oreilly.servlet.multipart.CoverFileRenamePolicy"%>
<%@page contentType="text/html; charset=gb2312" %>
<%
//文件上传后,保存在c:\\upload
String saveDirectory ="c:\\upload";
//每个文件最大5m,最多3个文件,所以...
int maxPostSize =3 * 5 * 1024 * 1024 ;
//response的编码为"gb2312",同时采用缺省的文件名冲突解决策略,实现上传
MultipartRequest multi =
new MultipartRequest(request, saveDirectory, maxPostSize,
"gb2312");
//输出反馈信息
Enumeration files = multi.getFileNames();
while (files.hasMoreElements()) {
System.err.println("ccc");
String name = (String)files.nextElement();
File f = multi.getFile(name);
if(f!=null){
String fileName = multi.getFilesystemName(name);
String lastFileName= saveDirectory+"\\" + fileName;
out.println("上传的文件:"+lastFileName);
out.println("
");
}
}
%>
最后把这2个文件发布到你的服务器就行了。上传文件就搞定啦,以后你想在你邮件系统里面嵌入发送附件的功能,用这个来做上传也不错啊。
最后,希望这篇文章对你有所启发,如有错误,敬请批评指正!
function TempSave(ElementID)
{
CommentsPersistDiv.setAttribute("CommentContent",document.getElementById(ElementID).value);
CommentsPersistDiv.save("CommentXMLStore");
}
function Restore(ElementID)
{
CommentsPersistDiv.load("CommentXMLStore");
document.getElementById(ElementID).value=CommentsPersistDiv.getAttribute("CommentContent");
}
</td>
<td width="178" align="center" valign="top" class="ArticleTeitle">
</td>
</tr>
<tr>
<td height="25" colspan="2" valign="top" class="ArticleTeitle">
↑返回目录
前一篇: 发送html格式的邮件
后一篇: 使用EL、JSTL处理表单数据