您的位置:首页 > Web前端 > JavaScript

在jsp中使用smartupload组件上传文件

2017-05-31 09:50 676 查看
在jsp中使用smartupload组件上传文件
jsp对上传文件的支持不象php中支持的那么好,直接做成了函数,也不象asp中要通过组件才能实现。jsp中可以通过javabean来实现。但是我们没有必要自己去写一个上载的bean,在网上已经有了很多成型的技术,smartupload就是其中的一个。但是smartupload是将文件先读到服务器的内存中,所以上传太大的文件(超过100兆)有可能会出问题,也算是一个美中不足吧:)
先说一下提交的页面,smartupload组件要求用字节流的方式来提交
。下面就是个例子upload.htm:

  File

:   
  File

:   
  File

:   
align=right>
再来看一下接收的页面 ,我们把文件上传到服务器以后就直接把它再存入数据库中:upload.jsp
<%@ page contentType="text/html;charset=gb2312"%>

<%@ page import="java.sql.*"%>

<%@ page import="com.jspsmart.upload.*" %>

<%@ page import="DBstep.iDBManager2000.*"%>

<%
//实例化上载bean

com.jspsmart.upload.SmartUpload mySmartUpload=new com.jspsmart.upload.SmartUpload();
//初始化

mySmartUpload.initialize(pageContext);
//设置上载的最大值

mySmartUpload.setMaxFileSize(500 * 1024*1024);
//上载文件

mySmartUpload.upload();
//循环取得所有上载的文件

for (int i=0;i //取得上载的文件

com.jspsmart.upload.File myFile = mySmartUpload.getFiles().getFile(i);

if (!myFile.isMissing())

{
//取得上载的文件的文件名

String myFileName=myFile.getFileName();
//取得不带后缀的文件名

String suffix=myFileName.substring(0,myFileName.lastIndexOf('.'));
//取得后缀名

String ext= mySmartUpload.getFiles().getFile(0).getFileExt();
//取得文件的大小

int fileSize=myFile.getSize();
//保存路径

String aa=getServletContext().getRealPath("/")+"jsp";

String trace=aa+myFileName;
//取得别的参数

String explain=(String)mySmartUpload.getRequest().getParameter("text");

String send=(String)mySmartUpload.getRequest().getParameter("send");
//将文件保存在服务器端

myFile.saveAs(trace,mySmartUpload.SAVE_PHYSICAL);
//下面的是将上载的文件保存到数据库中
//将文件读到流中

java.io.File file = new java.io.File(trace);

java.io.FileInputStream fis = new java.io.FileInputStream(file);

out.println(file.length());
//打开数据库

ResultSet result=null;

String mSql=null;

PreparedStatement prestmt=null;

DBstep.iDBManager2000 DbaObj=new DBstep.iDBManager2000();

DbaObj.OpenConnection();
//将文件写到数据库中

mSql="insert into marklist (markname,password,marksize,markdate,MarkBody) values (?,?,?,?,?)";

prestmt =DbaObj.Conn.prepareStatement(mSql);

prestmt.setString(1, "aaa1");

prestmt.setString(2, "0000");

prestmt.setInt(3, fileSize);

prestmt.setString(4, DbaObj.GetDateTime());

prestmt.setBinaryStream(5,fis,(int)file.length());

DbaObj.Conn.setAutoCommit(true) ;

prestmt.executeUpdate();

DbaObj.Conn.commit();

out.println(("上载成功!!!").toString());

}

else

{ out.println(("上载失败!!!").toString()); }

}//与前面的if对应

%>
再说一下下载,下载分两种情况1。从数据库直接下载2。从服务器上下载
先说从数据库直接下载的情形:就是把输入流从数据库里读出来,然后转存为文件
<%@ page contentType="text/html; charset=gb2312" %>

<%@ page import="java.sql.*"%>

<%@ page import="java.io.*" %>

<%@ page import="DBstep.iDBManager2000.*"%>

<%

int bytesum=0;

int byteread=0;
//打开数据库

ResultSet result=null;

String Sql=null;

PreparedStatement prestmt=null;

DBstep.iDBManager2000 DbaObj=new DBstep.iDBManager2000();

DbaObj.OpenConnection();
//取得数据库中的数据

Sql="select * from t_local_zhongzhuan ";

result=DbaObj.ExecuteQuery(Sql);

result.next();
//将数据库中的数据读到流中

InputStream inStream=result.getBinaryStream("content");

FileOutputStream fs=new FileOutputStream( "c:/dffdsafd.doc");
byte[] buffer =new byte[1444];

int length;

while ((byteread=inStream.read(buffer))!=-1)

{

out.println("
"+byteread+"");

bytesum+=byteread;

System.out.println(bytesum);

fs.write(buffer,0,byteread);

}

%>
再说从服务器上下载的情形:
<%@ page contentType="text/html; charset=gb2312" %>

<%@ page import="java.io.*" %>

<%

String fileName = "zsc104.swf".toString();f//读到流中

InputStream inStream=new FileInputStream("c:/zsc104.swf");
//设置输出的格式

response.reset();

response.setContentType("bin");

response.addHeader("Content-Disposition","attachment; filename="" + fileName + """);
//循环取出流中的数据

byte[] b = new byte[100];

int len;

while((len=inStream.read(b)) >0)

response.getOutputStream().write(b,0,len);

inStream.close();

%>
好了,到这里只要不是太大的文件的上传下载的操作都可以完成了。
[@more@]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: