本文介绍两种:上传文件到server的方式

  一种是提交Form表单;还有一种是ajaxfileupload异步上传。



一、JSP中:

    1、提交Form表单

为了能完毕文件上传,我们应该将这两个表单域所在表单的enctype属性设置为multipart/form-data。

		<form action="uploadFiles_fourInsuranceFirstUpload.action" method="post" enctype="multipart/form-data">
文件标题:<input type="text" name="title" /><br>
选择文件:<input type="file" name="upload" /><br>
<input value="上传" type="submit" />
</form>

    2、ajaxfileupload异步上传

      <script src="${pageContext.request.contextPath}/script/jquery.js" type="text/javascript"></script>
<script src="${pageContext.request.contextPath}/script/ajaxfileupload.js" type="text/javascript"></script><pre name="code" class="javascript"> <script type="text/javascript" language="javascript">
//上传附件
function uploadFile() { $.ajaxFileUpload( {
url : 'tenantCredit_uploadFile.action', //你处理上传文件的服务端
type : 'post',
secureuri : false,
fileElementId : 'fileUpload',
dataType : 'text',
success : function(data) {
if (data == "true") {
alert("上传文件成功!");
} else {
alert("上传失败! " );
}
}
})
}
</script>
<input type="file" id="fileUpload" name="upload" value="上传" />
<input type="button" id="btnUploadFile" onclick="javascript:uploadFile();" value="保存记录"/>

二、Action中该怎样获取文件呢?

upload属性分别相应前面的表单域的upload属性。用于封装表单域的请求參数。

Action中包括了两个属性:

     uploadFileName:封装上传文件的文件名称

     uploadContentType:封装上传文件的文件类型。

Action类直接通过File类型属性直接封装了上传文件的文件内容,但这个File属性无法获取上传文件的文件名称和文件类型,所以Struts2直接将文件域中包括的上传文件名称和文件类型的信息封装到uploadFileName和uploadContentType属性中。

能够觉得:假设表单中包括一个name属性为xxx的文件域,则相应Action须要使用三个属性来封装该文件域的信息:

类型为File的xxx属性封装了该文件域相应的文件内容。(文中的 File upload属性中的upload就是以下两个string的属性的前缀)    

     类型为String的xxxFileName属性封装了该文件域相应的文件的文件名称。

     类型为String的xxxContentType属性封装了该文件域相应的文件的文件名称。

通过上面的三个属性,能够更简单地实现文件上传,所以能够直接通过调用getXxx()方法来获取上传文件的文件名称、文件类型和文件内容。

	// 封装上传文件域的属性
private File upload;
// 封装上传文件类型的属性
private String uploadContentType;
// 封装上传文件名称的属性
private String uploadFileName;
// 标记上传文件的结果:成功/失败
private String result; public File getUpload() {
return upload;
}
public void setUpload(File upload) {
this.upload = upload;
}
public String getUploadContentType() {
return uploadContentType;
}
public void setUploadContentType(String uploadContentType) {
this.uploadContentType = uploadContentType;
}
public String getUploadFileName() {
return uploadFileName;
}
public void setUploadFileName(String uploadFileName) {
this.uploadFileName = uploadFileName;
}
public String getResult() {
return result;
}
public void setResult(String result) {
this.result = result;
} // 上传附件
public String uploadFile() {
try {
String realpath = ServletActionContext.getServletContext().getRealPath("/data"); if (upload != null) {
File savefile = new File(new File(realpath), uploadFileName);
if (!savefile.getParentFile().exists())
savefile.getParentFile().mkdirs();
FileUtils.copyFile(upload, savefile);
ActionContext.getContext().put("message", "文件上传成功");
}
// 提示:上传成功
result = "true";
outPrint(response, result); } catch (Exception e) {
// 提示:上传失败
String result = "false";
outPrint(response, result);
}
return null;
}

三、比較上述两种方式的优缺点:

1.验证是否选中文件:

①提交Form方式:

缺点:假设未选中文件,用JS捕获后return false,也会提交Form!还须要在Action的方法中进行判定。

②Ajax方式:

若未选中文件,用JS进行判定return false,将不会提交Action

2.传递參数的方式

①提交Form方式-2种:

利用ModelDriven属性,在Action中直接获取相应控件的value

或JSP中标识一个id,后在Action中定义此id的get、set方法,就能够直接取到。

②Ajax方式-3种:

同①

或通过JS中url传參的方式

3.接收Action中的返回结果

①提交Form方式:

把返回结果放在值栈/Session中,后再JSP中取出。

②Ajax方式:

同①

或JS回调函数通过data获取Action的返回值。

或JS回调函数通过data获取Action中outPrint

综合上述比較。推荐使用Ajax方式上传文件





工作笔记4.struts2上传文件到server的更多相关文章

  1. 工作笔记——限定input上传文件对话框中能选取的文件的格式

    原文:http://www.dengzhr.com/frontend/1059 input[file]标签的accept属性可用于指定上传文件的 MIME类型 . 例如,想要实现默认上传图片文件的代码 ...

  2. Unable to find ‘struts.multipart.saveDir’ Struts2上传文件错误的解决方法

    Unable to find ‘struts.multipart.saveDir’ Struts2上传文件错误的解决方法 在使用struts2的项目中上传文件的时候出现了一个这样的错误: 2011-7 ...

  3. [JavaWeb基础] 009.Struts2 上传文件

    在web开发中,我们经常遇到要把文件上传下载的功能,这篇文章旨在指导大家完成文件上传功能 1.首先我们需要一个上传文件的页面. <!--在进行文件上传时,表单提交方式一定要是post的方式, 因 ...

  4. 利用struts2上传文件时,如果文件名中含有-符号,那么会出错

    利用struts2上传文件时,如果文件名中含有-符号,那么会出错 报错如下: HTTP Status 500 - C:\Program Files\Apache Software Foundation ...

  5. Android端通过HttpURLConnection上传文件到server

    Android端通过HttpURLConnection上传文件到server 一:实现原理 近期在做Androidclient的应用开发,涉及到要把图片上传到后台server中.自己选择了做Sprin ...

  6. 【要什么自行车】ASP.NET MVC4笔记02:上传文件 uploadify 组件使用

    参考:http://www.cnblogs.com/luotaoyeah/p/3321070.html 1.下载 uploadify 组件,copy至 Content文件夹 <link href ...

  7. struts2上传文件添加进度条

    给文件上传添加进度条,整了两天终于成功了. 想要添加一个上传的进度条,通过分析,应该是需要不断的去访问服务器,询问上传文件的大小.通过已上传文件的大小, 和上传文件的总长度来评估上传的进度. 实现监听 ...

  8. 关于Struts2上传文件的最大Size的设置

    今天使用Struts2的文件上传控件时,在struts.xml中,将处理上传的action中的fileUpload拦截器的maximumSize参数设置为5000000,上传了一个3M的文件后发现控制 ...

  9. 菜鸟学SSH(五)——Struts2上传文件

    上传文件在一个系统当中是一个很常用的功能,也是一个比较重要的功能.今天我们就一起来学习一下Struts2如何上传文件. 今天讲的上传文件的方式有三种: 1,以字节为单位传输文件: 2,Struts2封 ...

随机推荐

  1. SPOJ-913

    Query on a tree II Time Limit: 433MS   Memory Limit: 1572864KB   64bit IO Format: %lld & %llu Su ...

  2. ubuntu 16.04 qtcreator 闪退

    当用QtCreator 进行代码自动补全时,比如编写ros代码,ROS_INFO时候就会出现闪退,后面按照 http://doc.qt.io/qtcreator/creator-clang-codem ...

  3. python带cookie提交表单自动登录

    import urllib import urllib2 import cookielib login_url = "xxxxxxxxxxxxx" cj = cookielib.C ...

  4. 【转载】Linux kill, killall, kill -9

    1) 查看进程的方法:  ps -ef  或者 ps aux root     15087  0.0  0.0      0     0 ?        S    23:31   0:00 [kwo ...

  5. 并查集&线段树&树状数组&排序二叉树

    超级无敌巨牛逼并查集(带权并查集)https://vjudge.net/problem/UVALive-4487 带删点的加权并查集 https://vjudge.net/problem/UVA-11 ...

  6. ( 转 ) 什么是 JWT -- JSON WEB TOKEN

    什么是JWT Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC 7519).该token被设计为紧凑且安全的,特别适用于分布式站点 ...

  7. 线程同步CriticalSection

    孙鑫 第十五/十六课之四 线程同步CriticalSection 说明 在使用多线程时,一般很少有多个线程完全独立的工作.往往是多个线程同时操作一个全局变量来获取程序的运行结果.多个线程同时访问同一个 ...

  8. Java里的浅复制与深复制

    1.浅复制与深复制概念 ⑴浅复制(浅克隆) 被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象.换言之,浅复制仅仅复制所考虑的对象,而不 复制它所引用的对象. ...

  9. 【线段树】Gym - 100507C - Zhenya moves from parents

    线段树每个结点维护两个值,分别是这个区间的 负债 和 余钱. 按时间顺序从前往后看的时候,显然负债是单调不减的. 按时间顺序从后往前看的时候,显然余钱也是单调不减的,因为之前如果有余钱,可能会增加现在 ...

  10. 使用jQuery操作DOM(ppt练习)

    <!DOCTYPE html> <html> <head> <title>test3.html</title> <meta http- ...