应用用uploadFile组件实现简单上传的demo
使用用uploadFile组件实现简单上传的demo
最近公司做个ftp下载服务器,当然要做后台管理,所以其中也要上传,哎,项目现在需求还是不稳定,天天改啊改,把这个上传的部分跟大家分享下吧,希望大家可以给点意见,我做的支持多文件上传,当然其中我也参考了一些网络资料,起初本来想用swf组件也用上的,但是中间遇到了样式调整问题,而且不好调,就干脆没用啦,
1.jsp 主要代码:
<script language="javascript">
var num = 0;
function upload(){
document.getElementById("status").innerHTML = "文件上传中...";
document.getElementById("form").action = "AddFileTest" ;
document.getElementById("form").submit();
}
function additem(id)
{
var row,cell,str;
row = eval("document.all["+'"'+id+'"'+"]").insertRow();
if(row != null )
{
cell = row.insertCell();
str="<input type="+'"'+"file"+'"'+"id=uploadFile["+ num +"].file"+ " name=uploadFile["+ num +"].file><input type="+'"'+"button"+'"'+" value="+'"'+"删除"+'"'+" onclick='deleteitem(this,"+'"'+"tb"+'"'+");'>"
cell.innerHTML=str;
}
num++;
}
function deleteitem(obj,id)
{
var rowNum,curRow;
curRow = obj.parentNode.parentNode;
rowNum = eval("document.all."+id).rows.length - 1;
eval("document.all["+'"'+id+'"'+"]").deleteRow(curRow.rowIndex);
}
function callback(msg)
{
document.getElementById("status").innerHTML = "文件上传完成...<br>" + msg;
}
</script>
</head>
<body bgcolor="#ffffff">
<fieldset>
<div id="status"></div>
<form id="form" name="form" method="post" enctype="multipart/form-data">
<table id="tb">
</table>
<iframe name='hidden_frame' id="hidden_frame" style="display:none"></iframe>
<input type="button" name="btnAddFile" value="增加文件" onclick="additem('tb')"/>
<input type="button" name="btnUpload" value="上传" onclick="upload()"/>
</form>
</fieldset>
2.servlet代码:
package download.control;
import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;
import java.util.List;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileItemFactory;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
public class AddFileServlet extends HttpServlet {
public AddFileServlet(){
super();
}
public void init() throws ServletException {
System.out.println("+++++++++++AddFileServlet++++++++++");
}
public void init(ServletConfig config) throws ServletException{
super.init(config);
System.out.println("++++++++ AddFileServlet init(config) ++++++++") ;
}
public void destroy() {
super.destroy();
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("++++++++ AddFileServlet doPost ++++++++") ;
response.setContentType("text/html; charset=UTF-8");
try {
request.setCharacterEncoding("UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
PrintWriter out = response.getWriter();
/* 定义上传文件的存放路劲*/
String base = request.getSession().getServletContext().getRealPath("")+"\\admin\\upload";
/*定义上传文件的缓存位置*/
String temPath = request.getSession().getServletContext().getRealPath("")+"\\admin\\upload\\temp";
/* 当缓存或存储路劲不存在时将自动创建文件*/
if (!new File(base).isDirectory()){
new File(base).mkdirs();
}
if(!new File(temPath).isDirectory()){
new File(temPath).mkdirs();
}
try{
FileItemFactory factory = new DiskFileItemFactory();
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setHeaderEncoding("UTF-8");
upload.setSizeMax(10002400000l);
List<FileItem> items=null;
try{
items = upload.parseRequest(request);
}catch (FileUploadException e) {
// TODO: handle exception
e.printStackTrace();
}
Iterator i = items.iterator();
FileItem file = null;
while (i.hasNext()) {
FileItem item = (FileItem) i.next();
System.out.println(item);
System.out.println(item.getFieldName());
System.out.println(item.getName());
System.out.println(i.hasNext());
if(item.isFormField()){
System.out.println(item.getName());
}else{
file =item;
String fileName = file.getName();
System.out.println(fileName);
if(fileName!=null&&fileName!=""){
/* 得到文件类型 */
String fileType = file.getName().substring(file.getName().lastIndexOf("."), file.getName().length());
/* 判断文件类型*/
System.out.println(fileType);
/* 在本需求中管理员上传文件类型为压缩文件.war/.rar/.giz/.apk*/
if(fileType.toLowerCase().equals(".rar")||fileType.toLowerCase().equals(".giz")||fileType.toLowerCase().equals(".apk")){
base+="\\RarVsGiz\\" ;
}else if(fileType.toLowerCase().equals(".txt")||fileType.toLowerCase().equals(".doc")||fileType.toLowerCase().equals(".xls")||fileType.toLowerCase().equals(".pdf")
||fileType.toLowerCase().equals(".ppt")){
base+="\\Text\\";
}else if(fileType.toLowerCase().equals(".wmv") || fileType.toLowerCase().equals(".rm") || fileType.toLowerCase().equals(".rmvb") || fileType.toLowerCase().equals(".avi")
|| fileType.toLowerCase().equals(".flv")|| fileType.toLowerCase().equals(".f4v")||fileType.toLowerCase().equals(".mp4")){
base+="\\Video\\";
}else if(fileType.toLowerCase().equals(".jpg") || fileType.toLowerCase().equals(".gif") ||fileType.toLowerCase().equals(".bmp") || fileType.toLowerCase().equals(".png")
|| fileType.toLowerCase().equals(".tif")||fileType.toLowerCase().equals(".jpeg")){
base+="\\Images\\";
}else{
base+="\\Bad\\" ;
}
File newFile = new File(base+file.getName());
System.out.println(newFile);
System.out.println(file);
file.write(newFile);
base = request.getSession().getServletContext().getRealPath("")+"\\admin\\upload";
}
}
}
}catch (Exception e) {
// TODO: handle exception
e.getMessage();
}
out.flush();
out.close();
response.sendRedirect("uploadSucess.jsp");
}
}
由于我还没把代码分层好,所以都写在servlet拉,上面代码中特别注意的是:item.isFormField()这个方法,当时我一直以为这个方法时只要得文件信息这个方法就为true值,其实不然,这个方法时判断得到的数据类型是否是普通的表单数据类型,在此,我们的File不是普通的表单数据提交,所以返回值是false,这样在下面判断表单中是否有file文件就可以啦
在web。xml中配置servlet就不要多讲啦吧
最近公司做个ftp下载服务器,当然要做后台管理,所以其中也要上传,哎,项目现在需求还是不稳定,天天改啊改,把这个上传的部分跟大家分享下吧,希望大家可以给点意见,我做的支持多文件上传,当然其中我也参考了一些网络资料,起初本来想用swf组件也用上的,但是中间遇到了样式调整问题,而且不好调,就干脆没用啦,
1.jsp 主要代码:
<script language="javascript">
var num = 0;
function upload(){
document.getElementById("status").innerHTML = "文件上传中...";
document.getElementById("form").action = "AddFileTest" ;
document.getElementById("form").submit();
}
function additem(id)
{
var row,cell,str;
row = eval("document.all["+'"'+id+'"'+"]").insertRow();
if(row != null )
{
cell = row.insertCell();
str="<input type="+'"'+"file"+'"'+"id=uploadFile["+ num +"].file"+ " name=uploadFile["+ num +"].file><input type="+'"'+"button"+'"'+" value="+'"'+"删除"+'"'+" onclick='deleteitem(this,"+'"'+"tb"+'"'+");'>"
cell.innerHTML=str;
}
num++;
}
function deleteitem(obj,id)
{
var rowNum,curRow;
curRow = obj.parentNode.parentNode;
rowNum = eval("document.all."+id).rows.length - 1;
eval("document.all["+'"'+id+'"'+"]").deleteRow(curRow.rowIndex);
}
function callback(msg)
{
document.getElementById("status").innerHTML = "文件上传完成...<br>" + msg;
}
</script>
</head>
<body bgcolor="#ffffff">
<fieldset>
<div id="status"></div>
<form id="form" name="form" method="post" enctype="multipart/form-data">
<table id="tb">
</table>
<iframe name='hidden_frame' id="hidden_frame" style="display:none"></iframe>
<input type="button" name="btnAddFile" value="增加文件" onclick="additem('tb')"/>
<input type="button" name="btnUpload" value="上传" onclick="upload()"/>
</form>
</fieldset>
2.servlet代码:
package download.control;
import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;
import java.util.List;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileItemFactory;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
public class AddFileServlet extends HttpServlet {
public AddFileServlet(){
super();
}
public void init() throws ServletException {
System.out.println("+++++++++++AddFileServlet++++++++++");
}
public void init(ServletConfig config) throws ServletException{
super.init(config);
System.out.println("++++++++ AddFileServlet init(config) ++++++++") ;
}
public void destroy() {
super.destroy();
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("++++++++ AddFileServlet doPost ++++++++") ;
response.setContentType("text/html; charset=UTF-8");
try {
request.setCharacterEncoding("UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
PrintWriter out = response.getWriter();
/* 定义上传文件的存放路劲*/
String base = request.getSession().getServletContext().getRealPath("")+"\\admin\\upload";
/*定义上传文件的缓存位置*/
String temPath = request.getSession().getServletContext().getRealPath("")+"\\admin\\upload\\temp";
/* 当缓存或存储路劲不存在时将自动创建文件*/
if (!new File(base).isDirectory()){
new File(base).mkdirs();
}
if(!new File(temPath).isDirectory()){
new File(temPath).mkdirs();
}
try{
FileItemFactory factory = new DiskFileItemFactory();
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setHeaderEncoding("UTF-8");
upload.setSizeMax(10002400000l);
List<FileItem> items=null;
try{
items = upload.parseRequest(request);
}catch (FileUploadException e) {
// TODO: handle exception
e.printStackTrace();
}
Iterator i = items.iterator();
FileItem file = null;
while (i.hasNext()) {
FileItem item = (FileItem) i.next();
System.out.println(item);
System.out.println(item.getFieldName());
System.out.println(item.getName());
System.out.println(i.hasNext());
if(item.isFormField()){
System.out.println(item.getName());
}else{
file =item;
String fileName = file.getName();
System.out.println(fileName);
if(fileName!=null&&fileName!=""){
/* 得到文件类型 */
String fileType = file.getName().substring(file.getName().lastIndexOf("."), file.getName().length());
/* 判断文件类型*/
System.out.println(fileType);
/* 在本需求中管理员上传文件类型为压缩文件.war/.rar/.giz/.apk*/
if(fileType.toLowerCase().equals(".rar")||fileType.toLowerCase().equals(".giz")||fileType.toLowerCase().equals(".apk")){
base+="\\RarVsGiz\\" ;
}else if(fileType.toLowerCase().equals(".txt")||fileType.toLowerCase().equals(".doc")||fileType.toLowerCase().equals(".xls")||fileType.toLowerCase().equals(".pdf")
||fileType.toLowerCase().equals(".ppt")){
base+="\\Text\\";
}else if(fileType.toLowerCase().equals(".wmv") || fileType.toLowerCase().equals(".rm") || fileType.toLowerCase().equals(".rmvb") || fileType.toLowerCase().equals(".avi")
|| fileType.toLowerCase().equals(".flv")|| fileType.toLowerCase().equals(".f4v")||fileType.toLowerCase().equals(".mp4")){
base+="\\Video\\";
}else if(fileType.toLowerCase().equals(".jpg") || fileType.toLowerCase().equals(".gif") ||fileType.toLowerCase().equals(".bmp") || fileType.toLowerCase().equals(".png")
|| fileType.toLowerCase().equals(".tif")||fileType.toLowerCase().equals(".jpeg")){
base+="\\Images\\";
}else{
base+="\\Bad\\" ;
}
File newFile = new File(base+file.getName());
System.out.println(newFile);
System.out.println(file);
file.write(newFile);
base = request.getSession().getServletContext().getRealPath("")+"\\admin\\upload";
}
}
}
}catch (Exception e) {
// TODO: handle exception
e.getMessage();
}
out.flush();
out.close();
response.sendRedirect("uploadSucess.jsp");
}
}
由于我还没把代码分层好,所以都写在servlet拉,上面代码中特别注意的是:item.isFormField()这个方法,当时我一直以为这个方法时只要得文件信息这个方法就为true值,其实不然,这个方法时判断得到的数据类型是否是普通的表单数据类型,在此,我们的File不是普通的表单数据提交,所以返回值是false,这样在下面判断表单中是否有file文件就可以啦
在web。xml中配置servlet就不要多讲啦吧