1、名称:Smartupload组件
使用Smartupload上传文件
2、知识点
2.1、上次课程的主要知识点
1、 JavaBean的基础语法
2、 JavaBean的四种范围
2.2、本次预计讲解的知识点
1、 使用Smartupload上传文件
3、具体内容
在各个站点上经常发现的功能就是上传文件,如果要想在JSP中进行文件的上传,则必须使用一系列的IO操作,本身比较麻烦,所以一般上传的时候都直接使用各个上传组件:
• Smartupload:使用比较广泛的一个组件
• Apache FileUpload:Struts框架中使用的就是此种上传
3.1、直接上传文件
如果要想上传文件,则必须使用上传文件的控件框,类型为file。
SmartUpload01.htm:
<html>
<head>
<title>SmartUpload</title>
</head>
<body>
<form action="SmartUpload01.jsp" method="post">
选择文件:<input type="file" name="pic">
<input type="submit" value="上传">
</form>
</body>
</html>
如果要想实现上传,直接把smartupload.jar包拷贝到WEB-INF/lib目录之中,同时在WEB目录下建立一个upload文件夹,此文件夹保存全部的上传文件。
如果要想使用smartupload上传,则必须按照以下的步骤操作:
• 实例化Smartupload对象
• 初始化上传操作
• 准备上传
• 将上传的文件进行保存
SmartUpload01.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%@ page import="org.lxh.smart.*" %>
<html>
<head>
<title>Smartupload</title>
</head>
<body>
<%
// 1、实例化smartupload对象
SmartUpload smart = new SmartUpload() ;
// 2、初始化上传
smart.initialize(pageContext) ;
// 3、准备上传
smart.upload() ;
// 4、保存上传文件
smart.save("upload") ;
%>
</body>
</html>
程序运行完成之后,发现在上传的文件夹之中并没有任何的图片存在,这是因为上传的时候表单没有进行封装,因为现在表单中的内容不在像之前那样只是一个简单的文本了,对于图片,必须进行多媒体的封装,所以上传表单修改为以下形式:
<form action="SmartUpload01.jsp" method="post" enctype="multipart/form-data">
选择文件:<input type="file" name="pic">
<input type="submit" value="上传">
</form>
再次运行之后,发现图片已经可以正确的保存到了文件夹之中。
3.2、封装表单的问题
表单必须进行多媒体封装之后才可以进行上传的操作,但是一旦表单封装之后对于普通的数据却又无法取得,例如以下代码:
SmartUpload02.htm:
<html>
<head>
<title>SmartUpload</title>
</head>
<body>
<form action="SmartUpload02.jsp" method="post" enctype="multipart/form-data">
姓名:<input type="text" name="uname"><br>
选择文件:<input type="file" name="pic"><br>
<input type="submit" value="上传">
</form>
</body>
</html>
SmartUpload02.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%@ page import="org.lxh.smart.*" %>
<html>
<head>
<title>Smartupload</title>
</head>
<body>
<%
// 1、实例化smartupload对象
SmartUpload smart = new SmartUpload() ;
// 2、初始化上传
smart.initialize(pageContext) ;
// 3、准备上传
smart.upload() ;
// 4、保存上传文件
smart.save("upload") ;
%>
<h1>姓名:<%=request.getParameter("uname")%></h1>
</body>
</html>
以上的程序运行的时候发现了两个问题:
• 无法直接使用request对象,取得表单中的其他参数
• 新的文件替换掉了旧的文件
解决1:如果表单被封装之后,要取得封装表单里的内容,则只能使用smartupload中提供的特定方法完成,而且此方法必须在smartupload准备上传的语句之后。
<h1>姓名:<%=smart.getRequest().getParameter("uname")%></h1>
解决2:之前所有的上传文件,上传之后的文件名称与之前的名称是一样的,所以此时可以经过处理让用户自己决定上传的名称。
具体操作代码参考《3.3、重新命名文件名称》。
3.3、重新命名文件名称
在重新命名文件名称的时候,对于文件的原有后缀是不应该进行修改的,所以在命名之前必须先取得后缀名称。
SmartUpload03.htm:
<html>
<head>
<title>SmartUpload</title>
</head>
<body>
<form action="SmartUpload03.jsp" method="post" enctype="multipart/form-data">
图片名称:<input type="text" name="uname"><br>
选择文件:<input type="file" name="pic"><br>
<input type="submit" value="上传">
</form>
</body>
</html>
SmartUpload03.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%@ page import="org.lxh.smart.*" %>
<html>
<head>
<title>Smartupload</title>
</head>
<body>
<%
// 1、实例化smartupload对象
SmartUpload smart = new SmartUpload() ;
// 2、初始化上传
smart.initialize(pageContext) ;
// 3、准备上传
smart.upload() ;
// 取得上传的文件后缀
String ext = smart.getFiles().getFile(0).getFileExt() ;
// 取得用户自己输入的名称:
String name = smart.getRequest().getParameter("uname") ;
String fileName = name + "." + ext ;
// 保存文件
smart.getFiles().getFile(0).saveAs(getServletContext().getRealPath("/")+
"upload//"+fileName) ;
%>
<h1>姓名:<%=ext%></h1>
</body>
</html>
注意:
虽然此时,可以为上传的文件名称进行重命名,但是现在所有的名称是由客户端自己输入的,就很难保证不会有重复的情况发生。所以此时,最好可以为上传的图片随机设置一个文件名称,此名称可以不用重复。可以按照以下的方式声明:
• IP地址 + 时间戳 + 三位随机数
• 例如:
|- IP地址:192.168.1.254
|- 时间:2008-8-7 16:29:32.345
|- 三位随机数:123
|- 19216800125420080807162932345123.后缀
IPTimeStamp.java:
package org.lxh.util;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;
public class IPTimeStamp {
private SimpleDateFormat sdf = null;
private String ip = null;
public IPTimeStamp() {
}
public IPTimeStamp(String ip) {
this.ip = ip;
}
public String getIPTimeRand() {
StringBuffer buf = new StringBuffer();
if (this.ip != null) {
// 进行拆分操作
String s[] = this.ip.split("//.");
for (int i = 0; i < s.length; i++) {
buf.append(this.addZero(s[i], 3));
}
}
buf.append(this.getTimeStamp());
Random r = new Random();
for (int i = 0; i < 3; i++) {
buf.append(r.nextInt(10)) ;
}
return buf.toString();
}
private String addZero(String str, int len) {
StringBuffer s = new StringBuffer();
s.append(str);
while (s.length() < len) {
s.insert(0, "0");
}
return s.toString();
}
public String getDate() {
this.sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
return this.sdf.format(new Date());
}
public String getDateComplete() {
this.sdf = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒SSS毫秒");
return this.sdf.format(new Date());
}
public String getTimeStamp() {
this.sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
return this.sdf.format(new Date());
}
}
SmartUpload04.htm:
<html>
<head>
<title>SmartUpload</title>
</head>
<body>
<form action="SmartUpload04.jsp" method="post" enctype="multipart/form-data">
选择文件:<input type="file" name="pic"><br>
<input type="submit" value="上传">
</form>
</body>
</html>
SmartUpload04.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%@ page import="org.lxh.smart.*" %>
<%@ page import="org.lxh.util.*" %>
<html>
<head>
<title>Smartupload</title>
</head>
<body>
<%
// 1、实例化smartupload对象
SmartUpload smart = new SmartUpload() ;
// 2、初始化上传
smart.initialize(pageContext) ;
// 3、准备上传
smart.upload() ;
// 取得上传的文件后缀
String ext = smart.getFiles().getFile(0).getFileExt() ;
// 取得用户自己输入的名称:
IPTimeStamp its = new IPTimeStamp(request.getRemoteAddr()) ;
String fileName = its.getIPTimeRand() + "." + ext ;
// 保存文件
smart.getFiles().getFile(0).saveAs(getServletContext().getRealPath("/")
+"upload//"+fileName) ;
%>
<img src="upload/<%=fileName%>" width="300" height="200">
</body>
</html>
3.4、上传操作的相关说明
在开发中关于图片的上传有以下两种保存形式。
1、 直接在数据库之中建立一个BLOB字段,所有的文件通过IO流的方式向里面直接写文件,那么以后数据库备份的时候直接备份整个数据库即可,但是如果使用BLOB的话,在数据库更新的时候比较麻烦,BLOB字段更新不了。只能先删除再插入。
2、 直接把上传的图片保存在一个上传的文件夹之中,在数据库中做一个字段,保存图片的名称,之后在显示的时候直接通过<img>标签显示图片。这种做法,数据库的更改方便,但是备份的时候就需要两份了,一份是数据,另外一份是上传的图片。(使用后者)。
4、总结
1、 使用smartupload可以方便的实现文件的上传功能
2、 所有上传的内容文件需要进行重新命名
5、预习任务
1、 复习接口的定义、代理设计、工厂设计、对象引用传递、JDBC
2、 DAO设计模式(视频)
3、 简单Servlet程序
6、作业
使用Oracle下的emp表完成操作。
建立myemp表,表的结构和内容直接复制emp表(除了mgr、deptno字段之外),为myemp表中添加一个photo的字段,用于保存雇员的照片,此字段的长度为50。默认值为“nophoto.jpg”。
使用JSP+JDBC的方式完成对myemp表的CRUD操作,同时可以修改雇员已经上传好的照片。
删除雇员的时候也应该删除图片。
上传照片的时候,数据库中的photo字段,只保存图片的名称,在显示的时候直接使用<img>标签进行显示。图片名称使用IP地址+时间戳+三位随机数的方式生成。
-----------------------------------------------------------------------------------------------------------------------------------------------------
http://www.mldn.cn/articleview/2008-11-11/article_view_2886.htm