java中jsp对于file自带的控件filesjsp中session的用法法

Java实现文件上传 - 上善若水任方圆 - ITeye技术网站
博客分类:
最近自己在做一个小系统玩的时候涉及到了文件的上传,于是在网上找到Java上传文件的方案,最后确定使用common-fileupload实现上传操作。
用户添加页面有一个“上传”按钮,点击按钮弹出上传界面,上传完成后关闭上传界面。
commons.fileupload-1.2.0.jar、commons.logging-1.1.1.jar、commons.beanutils-1.8.0.jar、commons.collections-3.2.0.jar、commons.io-1.4.0.jar、commons.lang-2.1.0.jar
首先编写核心代码,Javascript打开上传页面,并且从上传页获取返回参数,最后数据返回给回调函数callback:
* 跳转到上传页
* functionId:功能ID
* fileType:文件类型
* maxSize:文件容量上限
* callback:回调函数,返回三个参数:文件真名、文件存放名和文件大小
function openUpload(functionId,fileType,maxSize,callback){
var url = root+"/CommonController.jhtml?method=goFileUpload&";
if(functionId!=null){
url = url + "functionId="+functionId+"&";
if(fileType!=null){
url = url + "fileType="+fileType+"&";
if(maxSize!=null){
url = url + "maxSize="+maxS
var win = window.showModalDialog(url,"","dialogWidth:300dialogHeight:150scroll:status:no");
if(win != null){
var arrWin = win.split(",");
callback(arrWin[0],arrWin[1],arrWin[2]);
用户添加页面相关代码,点击“上传”按钮时调用上面的核心js代码,并且获取返回值
function openUpload_(){
openUpload(null,'JPG,GIF,JPEG,PNG','5',callback);
* 回调函数,获取上传文件信息
* realName真实文件名
* saveName文件保存名
* maxSize文件实际大小
function callback(realName,saveName,maxSize){
$("#photo_").val(saveName);
//回调后其它操作
&td&头像:&/td&
&input type="hidden" name="photo" id="photo_"&&/input&
&input type="button" onclick="openUpload_()" value="上传"/&
文件上传的JSP代码,需要注意的是在head标签内添加&base target="_self"&以防止页面跳转时弹出新窗口,用户选择指定文件,点击上传时就提交表单访问指定后台代码
&%@ include file="/WEB-INF/jsp/header.jsp" %&
&%@ page language="java" contentType="text/ charset=UTF-8"
pageEncoding="UTF-8"%&
&!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"&
&meta http-equiv="Content-Type" content="text/ charset=ISO-8859-1"&
&meta http-equiv="pragma" content="no-cache" /&
&base target="_self"&
&title&文件上传&/title&
&h5&文件上传&/h5&&hr/&
&form id="file_upload_id" name="file_upload_name" action="&%=root%&/CommonController.jhtml?method=doFileUpload" method="post" enctype="multipart/form-data"&
&input type="hidden" name="functionId" value="${functionId}"/&
&input type="hidden" name="fileType" value="${fileType}"/&
&input type="hidden" name="maxSize" value="${maxSize}"/&
&div&&input type="file" name="file_upload"/&&/div&
&c:if test="${maxSize!=null}"&
&div style="font: 12"&文件最大不能超过${maxSize}MB&/div&
&c:if test="${fileType!=null}"&
&div style="font: 12"&文件格式必须是:${fileType}&/div&
&div&&input type="submit" value="上传"/&&/div&
CommonController目前有两个方法,一个是跳转到上传页面的方法,一个是执行上传操作的方法doFileUpload,上传方法运行的大概逻辑是:首先获取页面的请求参数,fileType用于限制上传文件格式,
maxSize用于限制上传文件最大值,随后创建上传目录上传即可。
public class CommonController extends BaseController {
Log log = LogFactory.getLog(CommonController.class);
Properties fileUploadPro =
public CommonController(){
fileUploadPro = PropertiesUtil.getPropertiesByClass("fileupload.properties");
public ModeAndView init(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
* 跳转到文件上传页
* @param request
* @param response
* @throws ServletException
* @throws IOException
public ModeAndView goFileUpload(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
String functionId = request.getParameter("functionId");
String fileType = request.getParameter("fileType");
String maxSize = request.getParameter("maxSize");
ModeAndView mav = new ModeAndView("/WEB-INF/jsp/common/fileUpload.jsp");
if(functionId!=null && !"".equals(functionId.trim())){
mav.addObject("functionId", functionId);
if(fileType!=null && !"".equals(fileType.trim())){
mav.addObject("fileType", fileType);
if(maxSize!=null && !"".equals(maxSize.trim())){
mav.addObject("maxSize", maxSize);
* 上传文件
* @param request
* @param response
* @throws ServletException
* @throws IOException
@SuppressWarnings("unchecked")
public ModeAndView doFileUpload(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
//获取并解析文件类型和支持最大值
String functionId = request.getParameter("functionId");
String fileType = request.getParameter("fileType");
String maxSize = request.getParameter("maxSize");
//临时目录名
String tempPath = fileUploadPro.getProperty("tempPath");
//真实目录名
String filePath = fileUploadPro.getProperty("filePath");
FileUtil.createFolder(tempPath);
FileUtil.createFolder(filePath);
DiskFileItemFactory factory = new DiskFileItemFactory();
//最大缓存
factory.setSizeThreshold(5*1024);
//设置临时文件目录
factory.setRepository(new File(tempPath));
ServletFileUpload upload = new ServletFileUpload(factory);
if(maxSize!=null && !"".equals(maxSize.trim())){
//文件最大上限
upload.setSizeMax(Integer.valueOf(maxSize)*);
//获取所有文件列表
List&FileItem& items = upload.parseRequest(request);
for (FileItem item : items) {
if(!item.isFormField()){
String fileName = item.getName();
//检查文件后缀格式
String fileEnd = fileName.substring(fileName.lastIndexOf(".")+1).toLowerCase();
if(fileType!=null && !"".equals(fileType.trim())){
boolean isRealType =
String[] arrType = fileType.split(",");
for (String str : arrType) {
if(fileEnd.equals(str.toLowerCase())){
isRealType =
if(!isRealType){
//提示错误信息:文件格式不正确
super.printJsMsgBack(response, "文件格式不正确!");
//创建文件唯一名称
String uuid = UUID.randomUUID().toString();
//真实上传路径
StringBuffer sbRealPath = new StringBuffer();
sbRealPath.append(filePath).append(uuid).append(".").append(fileEnd);
//写入文件
File file = new File(sbRealPath.toString());
item.write(file);
//上传成功,向父窗体返回数据:真实文件名,虚拟文件名,文件大小
StringBuffer sb = new StringBuffer();
sb.append("window.returnValue='").append(fileName).append(",").append(uuid).append(".").append(fileEnd).append(",").append(file.length()).append("';");
sb.append("window.close();");
super.printJsMsg(response, sb.toString());
("上传文件成功,JS信息:"+sb.toString());
}//end of if
}//end of for
}catch (Exception e) {
//提示错误:比如文件大小
super.printJsMsgBack(response, "上传失败,文件大小不能超过"+maxSize+"M!");
log.error("上传文件异常!",e);
至此一个文件上传即已实现,而且能够基本满足不同模块的上传通用性,我还留着个functionId参数用于以后针对不同模块上传文件到不同目录。
浏览 244463
[i][/i][/list][/img][/url][/url][flash=200,200][/flash]|[/size][/align]&&&&
支持一下。如果想要在前端校验文件的大小,然后才能上传应该怎么弄啊前端验证大小没做过,可以去网上查看一下用JS是否可以实现:/bit5566/blog/item/589cb44f8886913faec3ab1e.html
浏览: 1955680 次
来自: 成都
好像有道理!!
super.printJsMsg(response, sb.t ...
受教了!分享一个Dubbo分布式架构项目实战参考内容:http ...
请问楼主,我现在运行的项目没用到hadoop,但目前查询数据非 ...
虽然没用hibernate测试,但是用mysql测试超期比例并 ...JSP中Uploadify插件的使用(jQuery上传插件)
- 隔壁老王 - ITeye技术网站
博客分类:
1、下载最新的zip压缩包
2、从其中提取文件。
&& 下载插件安装包后,可以看到官方给出的例子。里面文件夹的几个主要文件:jquery.uploadify.js(完成上传功能的脚本文件,在调用页面引用)、uploadify.css(外观样式表)、uploader.swf(上传控件的主体文件,flash控件)、upload.php(服务器端处理文件,官方仅提供了php版的)。
下面我使用的是在MyEclipse部署的java版。注意:需要加入三个commons.jar包:io、logging、fileupload。
3、导入default.css,uploadify.css,jQuery脚本,swfobject脚本和Uploadify插件。并且添加调用插件使用$,在您的网页的&head&部分ready事件:
&%@ page language="java" contentType="text/ charset=utf-8"%&
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
&!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"&
&base href="&%=basePath%&"&
&title&Upload&/title&
&!--装载文件--&
&link href="css/default.css" rel="stylesheet" type="text/css" /&
&link href="css/uploadify.css" rel="stylesheet" type="text/css" /&
&script type="text/javascript" src="scripts/jquery-1.3.2.min.js"&&/script&
&script type="text/javascript" src="scripts/swfobject.js"&&/script&
&script type="text/javascript" src="scripts/jquery.uploadify.v2.1.0.min.js"&&/script&
&!--ready事件--&
&script type="text/javascript"&
$(document).ready(function() {
$("#uploadify").uploadify({
'uploader'
: 'uploadify.swf',
: 'servlet/Upload',//后台处理的请求
'cancelImg'
: 'images/cancel.png',
: 'uploads',//您想将文件保存到的路径
: 'fileQueue',//与下面的id对应
'queueSizeLimit'
'fileDesc'
: 'rar文件或zip文件’,
'fileExt' : '*.*.zip', //控制可上传文件的扩展名,启用本项时需同时声明fileDesc
'simUploadLimit' : 2,
'buttonText'
: 'BROWSE'
&div id="fileQueue"&&/div&
&input type="file" name="uploadify" id="uploadify" /&
&a href="javascript:jQuery('#uploadify').uploadifyUpload()"&开始上传&/a&&
&a href="javascript:jQuery('#uploadify').uploadifyClearQueue()"&取消所有上传&/a&
4、后台处理的upload.java
package com.xzit.
import java.io.F
import java.io.IOE
import java.util.I
import java.util.L
import java.util.UUID;
import javax.servlet.ServletE
import javax.servlet.http.HttpS
import javax.servlet.http.HttpServletR
import javax.servlet.http.HttpServletR
import mons.fileupload.FileI
import mons.fileupload.FileUploadE
import mons.fileupload.disk.DiskFileItemF
import mons.fileupload.servlet.ServletFileU
@SuppressWarnings("serial")
public class Upload extends HttpServlet {
@SuppressWarnings("unchecked")
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String savePath = this.getServletConfig().getServletContext()
.getRealPath("");
savePath = savePath + "/uploads/";
File f1 = new File(savePath);
System.out.println(savePath);
if (!f1.exists()) {
f1.mkdirs();
DiskFileItemFactory fac = new DiskFileItemFactory();
ServletFileUpload upload = new ServletFileUpload(fac);
upload.setHeaderEncoding("utf-8");
List fileList =
fileList = upload.parseRequest(request);
} catch (FileUploadException ex) {
Iterator&FileItem& it = fileList.iterator();
String name = "";
String extName = "";
while (it.hasNext()) {
FileItem item = it.next();
if (!item.isFormField()) {
name = item.getName();
long size = item.getSize();
String type = item.getContentType();
System.out.println(size + " " + type);
if (name == null || name.trim().equals("")) {
//扩展名格式:
if (name.lastIndexOf(".") &= 0) {
extName = name.substring(name.lastIndexOf("."));
File file =
//生成文件名:
name = UUID.randomUUID().toString();
file = new File(savePath + name + extName);
} while (file.exists());
File saveFile = new File(savePath + name + extName);
item.write(saveFile);
} catch (Exception e) {
e.printStackTrace();
response.getWriter().print(name + extName);
5、配置处理的servlet
Web.xml文件
&?xml version="1.0" encoding="UTF-8"?&
&web-app version="2.4"
xmlns="/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="/xml/ns/j2ee
/xml/ns/j2ee/web-app_2_4.xsd"&
&servlet-name&upload&/servlet-name&
&servlet-class&com.xzit.upload.Upload&/servlet-class&
&/servlet&
&servlet-mapping&
&servlet-name&upload&/servlet-name&
&url-pattern&/servlet/Upload&/url-pattern&
&/servlet-mapping&
&welcome-file-list&
&welcome-file&index.jsp&/welcome-file&
&/welcome-file-list&
&/web-app&
到这里就ok了哦。
转自:http://tangsong1005./blog/static//
浏览 19171
浏览: 2678730 次
来自: 北京
巩大星 写道就是用官方的例子中的kml文件,可以在openla ...
就是用官方的例子中的kml文件,可以在openlayers中正 ...
提供了一种很好地思路,但是为啥tomcat里面访问后,也没有背 ...
曾经一时兴起写了个五子棋的(完全自学前端),当初不会前端(我是 ...
2、采用文件流输出的方式下载
这一段里啥玩意啊,全是错误,不 ...jsp一次选择多个文件上传 - ITeye问答
谁有一次选择多个文件上传的例子啊
可以参考代码
多文件上传插件Stream,解决不同浏览器上传文件的插件,是Uploadify的Flash版和Html5版的结合,带进度条,并支持html5断点续传,拖拽等功能,下载地址:
Uploadify上传,可以上传多个文件,带有进度条,希望有所帮助!,下载地址:
能够一下选择多个文件上传?
我之前做的是通过动态创建多个的上传文件控件来实现的
竊以為可以用AJAX實現,用戶體驗比較快樂
流行的jspSmartUpload能实现一次性上传多个文件。看看一次上传多个文件的java代码如何写的(拿去修改,不需要再造轮子了):
//初始化工作
myUpload.initialize(pageContext);
//设定允许的文件后缀名
myUpload.setAllowedExtList("gif,jpg");
//设定允许上传的文件类型
//jpg:pjpeg
//text:plain
//html:html
//doc:msword
myUpload.setAllowedFileTypeList("gif,pjpeg");
//设定是否允许覆盖服务器上的同名文件
myUpload.setIsCover(false);
//设定允许上传所有文件的总大小
//myUpload.setTotalMaxFileSize(1000000);
//设定单个文件大小的限制
//myUpload.setMaxFileSize(100000);
String[] sourceName={"",""}; //文件的原始文件名数组
String myName=new String("");
//设定上传的物理路径
myUpload.setRealPath(application.getRealPath(File.separator +"example" +File.separator +"e1_uploadFiles"));
//将所有数据导入组件的数据结构中
myUpload.upload();
catch(Exception e){}
//得到所有上传的文件
files myFiles=myUpload.getFiles();
//将文件保存到服务器
for(int i=0;i&myFiles.getCount();i + +)
myName="myName";
myName=myName +"_" +i +"." +myFiles.getFile(i).getExtName();
sourceName[i]=myFiles.getFile(i).getName();
myFiles.getFile(i).setName(myName);
//有两种保存方法,一种是保存在myUpload.setRealPath()的设定路径中,使用saveAs(),一种是另外保存到其他文件夹,使用.saveAs(String realPath)
myFiles.getFile(i).saveAs();
catch (Exception e) {}
到处都是例子代码
http://www.23book.net/SoftwareDev/Java/52657.htm
/article.asp?id=918
已解决问题
未解决问题【图文】第十章 JSP的文件操作_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
评价文档:
第十章 JSP的文件操作
上传于|0|0|文档简介
&&web程序设计
大小:1.42MB
登录百度文库,专享文档复制特权,财富值每天免费拿!
你可能喜欢}

我要回帖

更多关于 jsp param 用法 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信