`

flashfileupload组件的应用(struts2)

阅读更多
讲两点:一是如何在Struts2中使用FlashFileUpload这个flash的上传插件;二是在使用flash上传插件时如何解决Session问题。

先说第一点,如何在Struts2中使用FlashFileUpload这个flash的上传插件。

以前做.net时,用过一个FlashFileUpload.swf批量文件上传工具,很帅很简单。
网址:http://www.codeproject.com/KB/aspnet/FlashUpload.aspx
因为这个用Flex写的客户端插件公开源码,而且实现的的相当完美,在asp.net中用起来,就是一两行代码的事,所以非常喜欢。

最近想在Struts2中实现批量上传(使用html的file标签时,一次只能选一个文件,我是想一下可以选多个文件),结果找了半天,大都是swf+ajax的,用起来太复杂了,代码也很繁多,实在没耐心了。
就想起FlashFileUpload来了,结果发现不知道怎么用,官网上只给出了C#的例子,上网找了半天也没找到在Struts2中用的例子,甚至jsp的例子也没找到,最后自己研究出来了,在这里公开一下,希望对大家有所帮助。

大家从官网上下载了压缩包解压后,会找到Upload.cs,从代码中可以看到HttpContext对象可以直接把文件对象分离出来,想对上传的临时文件进行转存时,也很方便:
C#代码
for(int j = 0; j < context.Request.Files.Count; j++)  
{  
    // get the current file  
    HttpPostedFile uploadFile = context.Request.Files[j];  
    // if there was a file uploded  
    if (uploadFile.ContentLength > 0)  
    {  
        // save the file to the upload directory  
          
        //use this if testing from a classic style upload, ie.   
 
        // <form action="Upload.axd" method="post" enctype="multipart/form-data">  
        //    <input type="file" name="fileUpload" />  
        //    <input type="submit" value="Upload" />  
        //</form>  
 
        // this is because flash sends just the filename, where the above   
        //will send the file path, ie. c:\My Pictures\test1.jpg  
        //you can use Test.thm to test this page.  
        //string filename = uploadFile.FileName.Substring(uploadFile.FileName.LastIndexOf("\\"));  
        //uploadFile.SaveAs(string.Format("{0}{1}{2}", tempFile, "Upload\\", filename));  
 
        // use this if using flash to upload  
        uploadFile.SaveAs(Path.Combine(uploadPath, uploadFile.FileName)); 

            for(int j = 0; j < context.Request.Files.Count; j++)
            {
                // get the current file
                HttpPostedFile uploadFile = context.Request.Files[j];
                // if there was a file uploded
                if (uploadFile.ContentLength > 0)
                {
                    // save the file to the upload directory
                   
                    //use this if testing from a classic style upload, ie.

                    // <form action="Upload.axd" method="post" enctype="multipart/form-data">
                    //    <input type="file" name="fileUpload" />
                    //    <input type="submit" value="Upload" />
                    //</form>

                    // this is because flash sends just the filename, where the above
                    //will send the file path, ie. c:\My Pictures\test1.jpg
                    //you can use Test.thm to test this page.
                    //string filename = uploadFile.FileName.Substring(uploadFile.FileName.LastIndexOf("\\"));
                    //uploadFile.SaveAs(string.Format("{0}{1}{2}", tempFile, "Upload\\", filename));

                    // use this if using flash to upload
                    uploadFile.SaveAs(Path.Combine(uploadPath, uploadFile.FileName));

但是到了Struts2中,文件上传使用的是fileUpload拦截器实现文件对象的注入,注入时需要明确file对象的name,如:
<@s.file name="file" label="选择上传文件" />
(使用FreeMarker模板)
后台对应的Action中,需要定义对应的【private File file;】属性及其set方法,这样fileUpload拦截器才能正确的将file对象注入(设置)到Action中。当然多文件上传时,需要使用如【private List<File> file;】样的属性。

现在问题来了,当使用FlashFileUpload这个flash的客户端上传组件时,我们无法得知或声明文件对象的name值,我们也没有办法象在.net中,使用HttpContext拿到文件列表。
我就是在这里卡壳了,后来终于想出了个办法来获知其name了,就是伟大的Debug,通过在fileUpload拦截器中设置断点,或是在自己的Action方法中加上取Request对象的语句,通过断点查看Request中存放的对象,就能找到FlashFileUpload组件中file对象对应的name了,那就是:Filedata,我们可以在Action中定义Filedata属性及其set方法,fileUpload拦截器就可以正确的将FlashFileUpload组件提交上来的文件对象设到Filedata里了。
代码示例:
Java代码
/** 文件对象 */ 
private List<File> Filedata;  
 
/** 文件名 */ 
private List<String> FiledataFileName;  
 
/** 文件内容类型 */ 
private List<String> FiledataContentType;  
 
/** 
* @return the filedata 
*/ 
public List<File> getFiledata() {  
    return Filedata;  
}  
 
/** 
* @param filedata the filedata to set 
*/ 
public void setFiledata(List<File> filedata) {  
    Filedata = filedata;  
}  
 
/** 
* @return the filedataFileName 
*/ 
public List<String> getFiledataFileName() {  
    return FiledataFileName;  
}  
 
/** 
* @param filedataFileName the filedataFileName to set 
*/ 
public void setFiledataFileName(List<String> filedataFileName) {  
    FiledataFileName = filedataFileName;  
}  
 
/** 
* @return the filedataContentType 
*/ 
public List<String> getFiledataContentType() {  
    return FiledataContentType;  
}  
 
/** 
* @param filedataContentType the filedataContentType to set 
*/ 
public void setFiledataContentType(List<String> filedataContentType) {  
    FiledataContentType = filedataContentType;  


/** 文件对象 */
private List<File> Filedata;

/** 文件名 */
private List<String> FiledataFileName;

/** 文件内容类型 */
private List<String> FiledataContentType;

/**
* @return the filedata
*/
public List<File> getFiledata() {
return Filedata;
}

/**
* @param filedata the filedata to set
*/
public void setFiledata(List<File> filedata) {
Filedata = filedata;
}

/**
* @return the filedataFileName
*/
public List<String> getFiledataFileName() {
return FiledataFileName;
}

/**
* @param filedataFileName the filedataFileName to set
*/
public void setFiledataFileName(List<String> filedataFileName) {
FiledataFileName = filedataFileName;
}

/**
* @return the filedataContentType
*/
public List<String> getFiledataContentType() {
return FiledataContentType;
}

/**
* @param filedataContentType the filedataContentType to set
*/
public void setFiledataContentType(List<String> filedataContentType) {
FiledataContentType = filedataContentType;
}


其他转存的代码就与Struts2中多文件上传的代码一模一样了。至此,我们就可以用最少的代码,来实现非常完美的批量上传了,效果相当不错。因为公开源码,所以如果你愿意,可以把FlashFileUpload这个flex做的组件改的更好看,或增加点自己的代码,我抓个粗略的效果图:



下面说一下第二点:使用flash上传插件时如何解决Session问题
在使用Flash上传文件时,存在一个Session丢失的问题。我们做文件上传时,一般都需要用户登录后,才允许上传,但是我发现在使用了Flash上传插件后,一上传Session就丢了,也就是说,在后台处理中,从Session中是取不到判断用户是否登录的标识的,原因是通过Flash上传时发起了一个独立于浏览器之外的请求,在后台程序中是无法通过Cookie取到对应的sessionId的,也就无法判断出用户是否登录了。
解决之法就是在jsp或ftl文件中定义flash上传组件的代码时,把sessionId顺便登记上,这样,通过【url;jsessionid=】的形式,可以把sessionId通过URL传到后台,就可以使Session不丢失了。
示例代码(FreeMarker):
Html代码
<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0" 
    width="100%" height="100%" id="file" align="middle"> 
    <param name="allowScriptAccess" value="sameDomain" /> 
    <param name="movie" value="/flash/FlashFileUpload.swf?ver=2009041702" /> 
    <param name="quality" value="high" /> 
    <param name="wmode" value="transparent"> 
    <param name="FlashVars" value='fileTypeDescription=JPG格式图片&fileTypes=*.jpg;*.jpeg&fileSizeLimit=3000000&totalUploadSize=10240000&uploadPage=/performMultiuploadForDemo;jsessionid=${session.id}?username=${username}'> 
    <embed src="/flash/FlashFileUpload.swf?ver=2009041702" FlashVars='fileTypeDescription=JPG格式图片&fileTypes=*.jpg;*.jpeg&fileSizeLimit=3000000&totalUploadSize=10240000&uploadPage=/performMultiuploadForDemo;jsessionid=${session.id}?username=${username}' 
        quality="high" wmode="transparent" width="100%" height="100%" name="file" 
        align="middle" allowscriptaccess="sameDomain" type="application/x-shockwave-flash" 
        pluginspage="http://www.macromedia.com/go/getflashplayer" /> 
</object>> 

            <object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0"
                width="100%" height="100%" id="file" align="middle">
                <param name="allowScriptAccess" value="sameDomain" />
                <param name="movie" value="/flash/FlashFileUpload.swf?ver=2009041702" />
                <param name="quality" value="high" />
                <param name="wmode" value="transparent">
                <param name="FlashVars" value='fileTypeDescription=JPG格式图片&fileTypes=*.jpg;*.jpeg&fileSizeLimit=3000000&totalUploadSize=10240000&uploadPage=/performMultiuploadForDemo;jsessionid=${session.id}?username=${username}'>
                <embed src="/flash/FlashFileUpload.swf?ver=2009041702" FlashVars='fileTypeDescription=JPG格式图片&fileTypes=*.jpg;*.jpeg&fileSizeLimit=3000000&totalUploadSize=10240000&uploadPage=/performMultiuploadForDemo;jsessionid=${session.id}?username=${username}'
                    quality="high" wmode="transparent" width="100%" height="100%" name="file"
                    align="middle" allowscriptaccess="sameDomain" type="application/x-shockwave-flash"
                    pluginspage="http://www.macromedia.com/go/getflashplayer" />
            </object>>

好了,写完收工。
分享到:
评论

相关推荐

    flashfileupload组件的应用(struts1)

    集成FlashFileUpload组件到Struts1应用的步骤通常包括以下部分: 1. **引入依赖**:首先,你需要在项目中添加FlashFileUpload组件的库文件,通常是JAR包,并确保它们在类路径中可用。 2. **配置Action**:在Struts...

    struts2控制组件

    struts2控制组件!

    Struts2接口文档

    总的来说,Struts2接口文档是学习和使用Struts2框架不可或缺的工具,它能帮助开发者高效地理解和使用框架提供的各种组件和接口,提升开发效率,减少错误,并有助于深入理解MVC模式在实际项目中的应用。通过仔细研读...

    struts2项目开发

    Struts2 框架的主要组件包括 Action、Interceptor、Result、View 等。Action 负责处理用户的请求,Interceptor 负责拦截和处理请求,Result 负责处理请求的结果,View 负责将处理结果显示给用户。 Struts2 项目开发...

    Struts2基础应用二

    在实际应用中,理解并熟练使用Struts2的这些组件和机制,可以提高开发效率,降低维护成本。例如,通过配置Action和拦截器,可以实现请求的统一处理和业务逻辑的解耦。使用OGNL,可以方便地在Action与视图间传递复杂...

    struts2-scan_struts2-scan_struts2scan_scan_struts2漏洞_

    Struts2漏洞通常涉及到框架的核心组件,例如OGNL(Object-Graph Navigation Language)表达式,这是一种强大的语言,允许在运行时动态地操作对象属性。2017年,一个名为CVE-2017-9805的重大漏洞被发现,它允许远程...

    Struts2漏洞检查工具Struts2.2019.V2.3

    1. 自动扫描:自动扫描应用程序中的Struts2组件,查找已知的安全漏洞。 2. 漏洞报告:生成详细的漏洞报告,列出所有发现的问题以及修复建议。 3. 静态代码分析:对源代码进行分析,寻找潜在的安全问题。 4. 实时监控...

    struts的视图组件介绍

    总结,Struts的视图组件主要依赖于JSP、Tiles、Struts2标签库以及Ajax技术,它们共同协作以实现用户界面的呈现。理解并熟练掌握这些组件的使用,能帮助开发者构建出功能强大、易于维护的Web应用。在实际开发中,结合...

    Struts 2常用jar包

    5. **struts2-dojo-plugin-2.1.6.jar**:这个插件引入了Dojo JavaScript库的支持,为Struts 2应用提供了丰富的AJAX功能和用户界面组件,如datetimepicker。它使得开发者可以方便地创建具有交互性和动态效果的Web页面...

    Struts 2的高级应用

    1、MVC 概述 2、Struts1.x简述 3、Struts2概述 4、编写一个struts2应用程序 5、Struts2的核心配置文件 6、Action的实现 7、拦截器

    struts2验证框架

    Struts2 验证框架是基于 Java 语言的 Web 应用程序框架,提供了一个强大的验证机制,以确保用户输入的数据满足业务逻辑的要求。在 Struts2 中,验证机制是通过 validator 来实现的,该机制可以对用户输入的数据进行...

    struts2的各种jar包

    综上所述,"struts2的各种jar包"涵盖了构建Struts2应用所需的所有组件,从基础框架到特定功能的扩展,它们共同构建了一个强大且灵活的MVC框架。理解并熟练掌握这些知识点,将有助于你高效地开发和维护基于Struts2的...

    Struts2视频教程

    - **Action类详解**:Action类是Struts2的核心组件之一,负责处理用户的请求并返回相应的结果。了解如何编写Action类、设置其属性以及处理请求参数至关重要。 - **Result配置**:Result用于指定Action执行后的结果...

    Struts 原理 与 应用

    Struts 是一个开源的Java Web框架,主要用于构建基于MVC(模型-视图-控制器)设计模式的Web应用程序。这个框架旨在提高应用的结构化和可维护性,它是在J2EE平台上发展起来的,特别是在JSP Model 2的基础上进行了...

    尚硅谷_佟刚_Struts2

    Struts2是一个强大的Java web应用程序框架,用于构建和管理MVC(模型-视图-控制器)架构的应用程序。由Apache软件基金会维护,它是Struts1的升级版,提供了更先进的特性和更好的性能。尚硅谷_佟刚_Struts2的讲解课件...

    struts2 API帮助文档

    Struts2是一个强大的Java web应用程序框架,用于构建MVC(模型-视图-控制器)架构的应用。这个API帮助文档是开发者在使用Struts2框架时的重要参考资料,它详细阐述了框架的各种组件、类库和方法,有助于理解并有效...

    Struts2主要Lib

    Struts2是一个强大的Java web应用程序框架,用于构建和管理MVC(模型-视图-控制器)架构的应用程序。它的核心库由一系列的JAR(Java Archive)文件组成,这些文件包含了实现其功能的各种组件和依赖。在提供的"Struts...

    struts2 jar包

    总的来说,Struts2 jar包是实现MVC架构的利器,它通过组件化、插件化的设计,使得开发者可以快速构建健壮、可维护的Web应用程序。然而,随着Spring MVC和其他现代框架的崛起,Struts2的市场份额有所下降,但其设计...

    Struts 2实战 struts2 in Action

    根据提供的文件信息,我们可以从《Struts 2实战 Struts2 in Action》这一书籍中提炼出与Struts 2框架相关的多个重要知识点。Struts 2是一个基于Java的开源Web应用框架,它继承了Struts 1的优点并进行了大量的改进和...

Global site tag (gtag.js) - Google Analytics