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

Struts2+jquery.form.js实现图片与文件上传的方法

2016-05-05 00:00 981 查看
本文实例讲述了Struts2+jquery.form.js实现图片与文件上传的方法。分享给大家供大家参考,具体如下:

jquery.form.js是jQuery的一个官方用语支持异步上传文件的插件。官方网站:http://plugins.jquery.com/form/

结合Struts2三步轻松实现文件上传

一般是针对一个页面可能不止一个Form表单,所以在一个面提交表单会影响到另一个表单,为此,图片上传表单就可以使用无刷新提交方式上传,也就是异步上传,这时jquery.from.js就派上用场了。

一、HTML

导入本jS到页面、写好上传表单

<script type="text/javascript" src="/js/jquery.form.js"></script>
<!―图片上传 -->
<s:form id="picForm" name="picForm" action="/notice/showAddNotice.action" method="post"
enctype="multipart/form-data">
<input type="file" name="pic" size="30"/><input type="submit" value="上传"/>
</s:form>


二、JS

// 为表单绑定异步上传的事件
$(function(){
// 为表单绑定异步上传的事件
$("#picForm").ajaxForm({
url : "${pageContext.request.contextPath}/notice/uploadPic.action", // 请求的url
type : "post", // 请求方式
dataType : "text", // 响应的数据类型
async :true, // 异步
success : function(imageUrl){
//alert(imageUrl);
},
error : function(){
alert("数据加载失败!");
}
});
// 为提交按钮绑定事件
$("#saveBtn").click(function(){
// 表单输入较验
var title = $("#title");
// 获取textarea的内容
var content = tinyMCE.get('content').getContent();
var msg = "";
if ($.trim(title.val()) == ""){
msg = "公告标题不能为空!";
title.focus();
}else if ($.trim(content) == ""){
msg = "内容不能为空!";
}
msg = "";
if (msg != ""){
alert(msg);
}else{
// 表单提交
$("#noticeForm").submit();
}
});


三、Struts2Action

public class uploadPicAjax extends AbstractAjaxAction {
private static final long serialVersionUID = -4742151106080093662L;
/** Struts2文件上传的三个属性 */
private File pic;
private String picFileName;
private String picContentType;
@Override
protected String getJson() throws Exception {
//获取项目部署的路径
String realPath = ServletActionContext.getServletContext()
.getRealPath("/images/notice");
//生成新的文件名
String newFileName = UUID.randomUUID().toString()+"."
+FilenameUtils.getExtension(picFileName);// 获取文件的后缀名 aa.jpg --> jpg
FileUtils.copyFile(pic, new File(realPath + File.separator + newFileName));
return "/images/notice/" + newFileName;
}
/** setter and getter method **/
......
}


四、配置Struts2.xml

<!-- 图片的异步上传 -->
<action name="uploadPic" class="com.wise.hrm.action.notice.uploadPicAjax">
</action>


好了,从页面到后台就已经写完了。这样就可以上传了。完毕!

更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery切换特效与技巧总结》、《jQuery拖拽特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》、《jquery选择器用法总结》及《jQuery常用插件及用法总结

希望本文所述对大家jQuery程序设计有所帮助。

您可能感兴趣的文章:

使用jquery.form.js实现图片上传的方法
jQuery.form插件的使用及跨域异步上传文件
jQuery插件之jQuery.Form.js用法实例分析(附demo示例源码)
基于jQuery通过jQuery.form.js插件实现异步上传
基于jQuery通过jQuery.form.js插件使用ajax提交form表单
jquery.form.js实现将form提交转为ajax方式提交的方法
jquery.form.js用法之清空form的方法
Jquery.Form 异步提交表单的简单实例
IE中jquery.form中ajax提交没反应解决方法分享
解决3.01版的jquery.form.js中文乱码问题的解决方法
$.format,jquery.format 使用说明
asp.net+jquery.form实现图片异步上传的方法(附jquery.form.js下载)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息