`
fackyou200
  • 浏览: 310750 次
  • 性别: Icon_minigender_1
  • 来自: 山西太原
社区版块
存档分类
最新评论

Struts2 、jquery之ajaxfileupload异步上传插件

阅读更多

由于项目需求,在处理文件上传时需要使用到文件的异步上传。这里使用Jquery Ajax File Uploader这个组件下载地址http://www.phpletter.com/download_project_version.php?version_id=6
服务器端采用struts2来处理文件上传。
所需环境:
jquery.js
ajaxfileupload.js
struts2所依赖的jar包
及struts2-json-plugin-2.1.8.1.jar
编写文件上传的Action

package com.ajaxfile.action;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionSupport;

@SuppressWarnings("serial")
public class FileAction extends ActionSupport {

    private File file;
    private String fileFileName;
    private String fileFileContentType;

    private String message = "你已成功上传文件";
    
    public String getMessage() {
        return message;
    }

    public void setMessage(String message) {
        this.message = message;
    }

    public File getFile() {
        return file;
    }

    public void setFile(File file) {
        this.file = file;
    }

    public String getFileFileName() {
        return fileFileName;
    }

    public void setFileFileName(String fileFileName) {
        this.fileFileName = fileFileName;
    }

    public String getFileFileContentType() {
        return fileFileContentType;
    }

    public void setFileFileContentType(String fileFileContentType) {
        this.fileFileContentType = fileFileContentType;
    }

    @SuppressWarnings("deprecation")
    @Override
    public String execute() throws Exception {
        
        String path = ServletActionContext.getRequest().getRealPath("/upload");

        try {
            File f = this.getFile();
            if(this.getFileFileName().endsWith(".exe")){
                message="对不起,你上传的文件格式不允许!!!";
                return ERROR;
            }
            FileInputStream inputStream = new FileInputStream(f);
            FileOutputStream outputStream = new FileOutputStream(path + "/"+ this.getFileFileName());
            byte[] buf = new byte[1024];
            int length = 0;
            while ((length = inputStream.read(buf)) != -1) {
                outputStream.write(buf, 0, length);
            }
            inputStream.close();
            outputStream.flush();
        } catch (Exception e) {
            e.printStackTrace();
            message = "对不起,文件上传失败了!!!!";
        }
        return SUCCESS;
    }

}

 

struts.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
    <package name="struts2" extends="json-default">
        <action name="fileUploadAction" class="com.ajaxfile.action.FileAction">
            <result type="json" name="success">
                <param name="contentType">
                    text/html
                </param>
            </result>
            <result type="json" name="error">
                <param name="contentType">
                    text/html
                </param>
            </result>
        </action>
    </package>
</struts>    

 

注意结合Action观察struts.xml中result的配置。 

contentType参数是一定要有的,否则浏览器总是提示将返回的JSON结果另存为文件,不会交给ajaxfileupload处理。这是因为struts2 JSON Plugin默认的contentType为application/json,而ajaxfileupload则要求为text/html。
文件上传的jsp页面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>Insert title here</title>
        <script type="text/javascript" src="js/jquery.js"></script>
        <script type="text/javascript" src="js/ajaxfileupload.js"></script>
        <script type="text/javascript">
    function ajaxFileUpload()
    {
        
        $("#loading")
        .ajaxStart(function(){
            $(this).show();
        })//开始上传文件时显示一个图片
        .ajaxComplete(function(){
            $(this).hide();
        });//文件上传完成将图片隐藏起来
        
        $.ajaxFileUpload
        (
            {
                url:'fileUploadAction.action',//用于文件上传的服务器端请求地址
                secureuri:false,//一般设置为false
                fileElementId:'file',//文件上传空间的id属性  <input type="file" id="file" name="file" />
                dataType: 'json',//返回值类型 一般设置为json
                success: function (data, status)  //服务器成功响应处理函数
                {
                    alert(data.message);//从服务器返回的json中取出message中的数据,其中message为在struts2中action中定义的成员变量
                    
                    if(typeof(data.error) != 'undefined')
                    {
                        if(data.error != '')
                        {
                            alert(data.error);
                        }else
                        {
                            alert(data.message);
                        }
                    }
                },
                error: function (data, status, e)//服务器响应失败处理函数
                {
                    alert(e);
                }
            }
        )
        
        return false;

    }
    </script>
    </head>
    <body>
        <img src="loading.gif" id="loading" style="display: none;">
        <input type="file" id="file" name="file" />
        <br />
        <input type="button" value="上传" onclick="return ajaxFileUpload();">
    </body>
</html>

 

注意观察<body>中的代码,并没有form表单。只是在按钮点击的时候触发ajaxFileUpload()方法。需要注意的是js文件引入的先后顺序,ajaxfileupload.js依赖于jquery因此你知道的。

分享到:
评论
6 楼 tiancai2 2013-10-19  
如果在action中定义不是string类型的,而是一个Person类型的,它有两个属性,name,password;那么在前台如何获取name属性值,我用的是data.person2.name;person2是Person的一个的对象,但是这个方法也不行,所有还望博主请教,该如何获取?
5 楼 tiancai2 2013-10-19  
如果在action中定义不是string类型的,而是一个Person类型的,它有两个属性,name,password;那么在前台如何获取name属性值,我用的是data.person2.name;person2是Person的一个的对象,但是这个方法也不行,所有还望博主请教,该如何获取?
4 楼 平安一生 2013-02-04  

回博主:
在action中并没有定义名为error的属性,if(typeof(data.error) != 'undefined')  的判断只能是false,也就是说此处之所以还会alert返回的message,完全归功于31行alert(data.message);
请博主鉴定!
回复1楼:
如何才能让ajaxfileupload真正判断出返回结果是success还是error,而不是全都视为success。
你可以试试在action的处理方法中触发一个异常,返回到前台的信息应该是error
3 楼 liuInsect 2012-03-08  
为什么action里面的file 这个属性是null???
2 楼 ywlqi 2011-01-17  
回复1楼,虽然没有看过源代码,但应该不会错,ajaxfileupload的success 和 error句柄是根据http返回状态决定的,即200,都认为是成功,action 的 success 和 error两个result是在代码中控制的,属于业务逻辑上的success和error,返回状态都是200,所以ajaxfileupload都会调用success方法,要想调用error方法,需要抛出异常,例如500
其实怎么处理返回结果,还是要看具体的业务需求,我觉得action中返回error,是业务逻辑上发生了错误,属于正常情况,返回200是合理的,相应的,ajaxfileupload中if(typeof(data.error) != 'undefined') 的判断也是合理的
1 楼 lc87624 2011-01-05  
文章很受用 谢谢博主~

我有个问题想请教下。
action里SUCCESS和ERROR两个result好像本质并没有什么不同,返回到JavaScript里,ajaxfileupload均会视为success,而博主好像是通过alert显示不同的message信息来区分成功与否,alert之前有if(typeof(data.error) != 'undefined')  的判断,可是action中并没有定义名为error的属性,此处貌似会因为判断不通过而不alert任何信息。

我想问的是,如何才能让ajaxfileupload真正判断出返回结果是success还是error,而不是全都视为success。

可能说得不太明白,还望博主费心看一下~

相关推荐

    jquery 插件ajaxfileupload与struts2结合 实现异步上传图片

    在本文中,我们将深入探讨如何将jQuery插件AjaxFileUpload与Struts2框架结合,以实现异步图片上传的功能。这种技术在现代Web应用中非常常见,它提升了用户体验,允许用户在不刷新整个页面的情况下上传文件,特别是...

    jquery之ajaxfileupload异步上传插件(附工程代码)

    点我下载工程代码 由于项目需求,在处理文件... 所需环境: jquery.js ajaxfileupload.js struts2所依赖的jar包 及struts2-json-plugin-2.1.8.1.jar 编写文件上传的Action 代码如下: package com.ajaxfile.action; imp

    jquery ajaxfileupload异步上传插件

    在本文中,我们将探讨如何使用jQuery的ajaxfileupload插件实现异步文件上传,并结合Struts2框架进行处理。这个插件提供了一种方便的方法,允许用户在不刷新页面的情况下上传文件,提升用户体验。 首先,要使用...

    使用struts 2 和ajaxFileUpload组件实现图片上传预览(完整版)

    AjaxFileUpload是JQuery插件,用于实现异步文件上传功能,尤其适用于处理图片上传。在本文中,我们将详细介绍如何使用Struts 2和AjaxFileUpload组件来实现在Web应用程序中进行图片的上传与预览。 一、Struts 2 框架...

    jquery ajaxfileupload异步上传插件使用详解

    - 使用jQuery监听文件输入元素的点击事件(或其他适当的事件),在事件处理函数中调用`$.ajaxFileUpload`方法实现异步上传。 3. **文件校验**:在上传之前,插件支持对文件的类型、大小、尺寸等进行校验。这对于...

    struts2异步上传

    Struts2是一个非常流行的... Struts2异步上传结合了Struts2框架、jQuery、Ajax、JSON插件和文件处理策略,为用户提供了无刷新的文件上传体验。理解并熟练掌握这些组件和技术,对于开发高效、安全的Web应用至关重要。

    AjaxFileUpload Struts2 多文件上传

    本篇文章将深入讲解如何利用AjaxFileUpload与Struts2实现多文件上传,并结合jQuery进行前端交互。 首先,我们需要在项目中引入必要的库。Struts2提供了struts2-jquery-plugin,这是一个基于jQuery的插件,包含了...

    j​q​u​e​r​y​ ​i​m​g​a​r​e​a​s​e​l​e​c​t​ + ajaxfileupload + struts2实现图片的异步上传裁剪

    这个项目是基于jQuery的imgAreaSelect插件、ajaxfileupload.js以及Struts2框架来完成这一功能的。接下来,我们将深入探讨这些关键技术点。 首先,jQuery imgAreaSelect是一个强大的JavaScript插件,它允许用户在...

    Struts2+ajax+json异步上传图片回显

    在这个场景中,“Struts2+ajax+json异步上传图片回显”是指利用Struts2框架,通过Ajax技术实现图片的异步上传,并通过JSON进行数据交互,最终实现在页面上即时回显上传的图片。 首先,让我们理解每个组件的作用: ...

    ajaxFileUpload+struts2实现多文件上传(源码)

    同时,我们需要使用`ajaxFileUpload`插件来处理异步上传。例如: ```html ()"&gt;上传 &lt;script src="jquery.js"&gt; &lt;script src="ajaxfileupload.js"&gt; function uploadFiles() { $.ajaxFileUpload({ url: '...

    jquery异步上传

    **jQuery异步上传插件** 由于原生的jQuery并没有提供直接的文件上传功能,因此通常会使用第三方插件来实现。描述中提到的可能是指`ajaxfileupload.js`这样的插件。这类插件通常提供更友好的API和更多的自定义选项,...

    ajax+jquery+struct+ajaxfileupload有增删改功能上传文件例子

    2. jQuery监听到按钮点击事件,触发AjaxFileUpload插件,开始异步上传文件。 3. AjaxFileUpload会把文件数据和相关参数打包成HTTP请求,发送到后台Struts的Action。 4. Struts Action接收到请求后,进行必要的文件...

    struts jquery 上传

    在Struts中,文件上传通常依赖于`struts2-convention-plugin`和`struts2-plugins`中的`struts2-file-uploading`插件。这些插件提供了处理文件上传请求的Action和结果类型。首先,我们需要在Struts配置文件(`struts....

    struts2的上传和下载功能

    `ajaxfileupload.js`可能是一个用于前端文件上传的JavaScript库,如jQuery的AjaxFileUpload插件。它允许用户在不刷新页面的情况下上传文件,提高用户体验。你需要在JSP页面中引用这个脚本,并编写相应的JavaScript...

    jquery中的ajax异步上传

    知识点一:ajax异步上传 ajax异步上传是一种基于AJAX技术实现的文件上传方式,它可以在不刷新页面的情况下将文件上传到服务器。与传统的表单提交不同,ajax异步...这表明struts2框架也可以用于处理ajax异步上传的文件。

    struts2使用注解的上传下载功能

    - `canPushToItv.js`和`ajaxfileupload.js`可能是用于前端交互的JavaScript文件,特别是`ajaxfileupload.js`可能是一个用于异步文件上传的库,如jQuery的AjaxFileUpload插件。 - 这些脚本负责捕获表单数据,发送...

    AjaxFileUpload+Struts2实现多文件上传功能

    在本文中,我们将深入探讨如何使用AjaxFileUpload插件与Struts2框架相结合来实现多文件上传的功能。AjaxFileUpload是一种基于JavaScript的轻量级插件,它允许用户在不刷新整个页面的情况下上传文件,提高了用户体验...

Global site tag (gtag.js) - Google Analytics