从struts2动作类中的jquery-ajax传递的文件值中获取null

时间:2013-06-27 09:51:41

标签: javascript jquery struts2

我已经编写了一个代码,用于在从文件浏览器中选择文件时使用jquery-ajax将文件从jsp上传到mysql数据库。在选择文件时,JavaScript将文件和id作为参数传递给动作类,但我在动作类中获取了该值的空值。

任何人都可以告诉我如何解决这个问题。

的index.jsp

<%@taglib uri="/struts-tags" prefix="s"%>
<html>
<head>
<script src="js/jquery-1.7.2.min.js"></script>
<script src="js/jquery-ui-1.8.21.custom.min.js"></script>
<script>
    function filebrowse(toolid){
        document.getElementById("toolidforimg").value=toolid;
        $("#filetochange").trigger('click');
        return false;
    }

    function changeFile(var3)
    {
       var param="filetochange="+(document.getElementById("filetochange").value)+"&toolidforimg="+document.getElementById("toolidforimg").value;
        var resultStringX = $.ajax({
        type: "POST",
        url:"getFileChange.action", 
        enctype: 'multipart/form-data',
        data: param,
        async: false
        }).responseText;
        resultStringX=$.trim(resultStringX);

     return false;  
    }
</script>
</head>
<body>
<s:hidden value="" name="toolidforimg" id="toolidforimg"/>
<a href="#" onclick="return filebrowse('1')" id="select_logo">Change File</a>
<input style="opacity:0;" type="file" onchange="changeFile(this.value)" id="filetochange" name="filetochange" >
</body>
</html>

struts.xml中

<action name="getFileChange" class="com.MyactionClass" method="getFileChange">
     <result name="success">browseFiles.jsp</result>
</action>

MyactionClass.java

class MyactionClass
{
  File filetockhange;
  String toolidforimg;

  public File getFiletochange() {
        return filetochange;
    }

  public void setFiletochange(File filetochange) {
        this.filetochange = filetochange;
    }

   public String getToolidforimg() {
        return toolidforimg;
    }

   public void setToolidforimg(String toolidforimg) {
        this.toolidforimg = toolidforimg;
    }

   public String getFileChange()
   {
    HERE I AM GETTING filetochange VALUE AS NULL

    return SUCCESS;
   }
}

1 个答案:

答案 0 :(得分:0)

在您要发送的字段周围放置一个HTML表单元素(文件,隐藏等)。

这应该足够了。

一些提示:

  • 总是specify a DTD,否则你会陷入Quirks Mode的奇怪世界。在您的情况下,HTML5 DTD应该适合,因为您只能使用HTML5通过AJAX上传文件:使用<html>更改<!DOCTYPE html>
  • 尽可能使用Struts2代码而不是HTML代码,例如<s:form><s:file><s:a>
  • 只有访问者(getter)应该以{{1​​}}开头,而不是其他方法,并且肯定不是Action名称;