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


Posted in Javascript onMay 05, 2016

本文实例讲述了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程序设计有所帮助。

Javascript 相关文章推荐
jquery photoFrame 图片边框美化显示插件
Jun 28 Javascript
JS 实现获取打开一个界面中输入的值
Mar 19 Javascript
js多级树形弹出一个小窗口层(非常好用)实例代码
Mar 19 Javascript
JS组件Bootstrap实现下拉菜单效果代码
Apr 26 Javascript
js利用clipboardData实现截屏粘贴功能
Oct 12 Javascript
ExtJs整合Echarts的示例代码
Feb 27 Javascript
vue插件实现v-model功能
Sep 10 Javascript
如何使用 vue + d3 画一棵树
Dec 03 Javascript
浅谈Javascript常用正则表达式应用
Mar 08 Javascript
Vue基于iview实现登录密码的显示与隐藏功能
Mar 06 Javascript
解决React在安装antd之后出现的Can't resolve './locale'问题(推荐)
May 03 Javascript
详解ES6数组方法find()、findIndex()的总结
May 12 Javascript
使用jquery.form.js实现图片上传的方法
May 05 #Javascript
探讨:JavaScript ECAMScript5 新特性之get/set访问器
May 05 #Javascript
浅析JS异步加载进度条
May 05 #Javascript
AngularJS入门(用ng-repeat指令实现循环输出
May 05 #Javascript
图文详解Heap Sort堆排序算法及JavaScript的代码实现
May 04 #Javascript
一分钟理解js闭包
May 04 #Javascript
学JavaScript七大注意事项【必看】
May 04 #Javascript
You might like
探讨如何把session存入数据库
2013/06/07 PHP
关于Laravel参数验证的一些疑与惑
2019/11/19 PHP
php使用redis的有序集合zset实现延迟队列应用示例
2020/02/20 PHP
使用jquery实现div的tab切换实例代码
2013/05/27 Javascript
Javascript获取HTML静态页面参数传递值示例
2013/08/18 Javascript
JS中检测数据类型的几种方式及优缺点小结
2016/12/12 Javascript
详解MVC如何使用开源分页插件(shenniu.pager.js)
2016/12/16 Javascript
web 屏蔽BackSpace键实例代码
2016/12/24 Javascript
jquery实现页面加载效果
2017/02/21 Javascript
js仿微博动态栏功能
2017/02/22 Javascript
浅谈Node模块系统及其模式
2017/11/17 Javascript
element-ui 设置菜单栏展开的方法
2018/08/22 Javascript
详解ES6系列之私有变量的实现
2018/11/21 Javascript
详解NodeJS Https HSM双向认证实现
2019/03/12 NodeJs
nodejs微信开发之接入指南
2019/03/17 NodeJs
VUE兄弟组件传值操作实例分析
2019/10/26 Javascript
Vue SPA 首屏优化方案
2021/02/26 Vue.js
通过数据库向Django模型添加字段的示例
2015/07/21 Python
简单谈谈python中的多进程
2016/11/06 Python
浅谈dataframe中更改列属性的方法
2018/07/10 Python
python实现图像拼接
2020/03/05 Python
Python 通过正则表达式快速获取电影的下载地址
2020/08/17 Python
Zooplus葡萄牙:欧洲领先的网上宠物商店
2018/07/01 全球购物
英国自行车商店:AW Cycles
2021/02/24 全球购物
服装设计专业毕业生推荐信
2013/11/09 职场文书
数学教育专业求职信
2014/07/22 职场文书
公务员爱岗敬业演讲稿
2014/08/26 职场文书
村长反四风问题个人对照检查材料
2014/09/21 职场文书
群众路线个人剖析材料
2014/10/07 职场文书
党校党性分析材料
2014/12/19 职场文书
公司租车协议书
2015/01/29 职场文书
公司更名通知函
2015/04/24 职场文书
2015年超市收银员工作总结
2015/04/25 职场文书
2015教师个人师德工作总结
2015/10/23 职场文书
JavaScript如何优化逻辑判断代码详解
2021/06/08 Javascript
CSS中Single Div 绘图技巧的实现
2021/06/18 HTML / CSS