zoukankan      html  css  js  c++  java
  • 关于ajaxfileupload.js上传图片使用历程(struts2)

      因为要使用上传图片功能,附加图片的描述信息, 而传统的<s: file/>由于一些限制在这个小模块中无法使用, 于是搜到了使用ajaxfileupload.js插件进行上传的方法,在使用过程中,jsp,js,struts2

      因为自己不熟悉ajax的情况出了许多的小问题,在这里记录一下, 方便自己查看,也希望能帮到他人,

      首先说一下思路,通过点击上传直接触发js 的function 调用后台把图片拷贝到指定服务器目录,返回保存的路径到前台,然后跟随图片描述信息一起用ajax异步传到后台。(PS:如果有新的方法,麻烦请告知,我只会这个了)

      首先,我先把jsp代码贴上来,

    <input type="file" onchange="uploadImage(this)" id="newsImgFile" name="tbslidefile" />
    <input type="hidden" id="imgPath"  name="imgPath" />
    
    <div class="newlyhead">标题:</div>
    <div class="newlycontent"><input type="text" class="upload_title" id="slideTitle" name="slideTitle"></div>
    <input type="button"  value="保    存"  onclick="saveTwo();"  >

    记得添加进来需要的js插件,这里我自己写的js叫做index.js

    <script type="text/javascript" src="js/jquery.js"></script>
    <script type="text/javascript" src="js/ajaxfileupload.js"></script>
    <script type="text/javascript" src="js/index.js"></script>

    下面是我自己写的js代码

    function uploadImage(obj) {
        var fileElementId = "newsImgFile";  //注意这里newsImgFile是上面 input type="file"的 id 如果需要修改记得一起修改
        $("#newsImgFile").attr('name','file');  //明显.attr就是设置元素的属性值,当然如果单纯上传图片的话可以不用这么麻烦,直接在下面fileElementId:**属性跟input的id name一致就OK了,通过再次转换,可以方便在js中进行不同图片的控制,当然这里没用到
        alert("test");  //只是查看是否执行到了这里,可以去掉          
            $.ajaxFileUpload({
                url:'uploadAction',       //需要链接到服务器地址
                secureuri:false,
                fileElementId:fileElementId,                            //文件选择框的id属性
                dataType: 'json',                                   //服务器返回的格式,可以是其他
                success: function (response, status, xhr) {               //成功后的回调函数
                    console.log(response.obj);            //这个方法可以在浏览器(chrome等)审查元素时候控制台console输出
                        //alert(response.obj);
                        $('#imgPath').val(response.obj);      //这个就是为上面input id="imgPath"赋值,一起传到后台
                },
                error: function (data, status, e) {           //相当于java中catch语句块的用法
                    $('#imgPath').val('');
                }
            });
    }
    
    function saveTwo()
    {
        $.ajax({ 
        type: "post",
        dataType: "text",
        contentType:"application/x-www-form-urlencoded; charset=utf-8",
        url: "addSlide",     //都是Action因为是使用struts2框架
        data: {
            slideTitle:$("#slideTitle").val(),
            slidePath:$("#imgPath").val()
        },
        success: function(response, status, xhr) {
            console.log(response);  //response是返回的值
            alert(status);    //status是状态,例如success
            if(status=="success")
            {
                jAlert("添加成功!","提示信息");
            } 
            else
            {
                jAlert("添加失败!","提示信息");
            }
        } });
    }

    相信上面关于js的说明会很清楚,接下来是后台代码,单纯接收到js上传的图片并返回路径到前面js

    package *****
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileOutputStream;
    import java.text.SimpleDateFormat;
    import java.util.Date;
    
    import javax.servlet.http.HttpServletResponse;
    
    import net.sf.json.JSONArray;
    import net.sf.json.JSONObject;
    
    import org.apache.struts2.ServletActionContext;
    
    import com.opensymphony.xwork2.ActionSupport;
    
    /**
     *@author  E—mail:
     *@version  create time:2014-6-16上午10:43:43
     *class introduce
     */
    public class UploadAction extends ActionSupport {
    
        private File file;
        private String fileFileName;
        
        private String savePath;
        private String obj;
        /**
         * 私有变量file要和js中$("#newsImgFile").attr('name','file');一致,这样可以直接接受过来
         * 这里是单纯的图片上传到服务器,这个savePath是在struts.xml中配置的
         * 
         *  
         */
        @Override
        public String execute() throws Exception {
            String bigurl = "";
            SimpleDateFormat sf = new SimpleDateFormat("yyyyMMddHHmmss");
            Date now = new Date();
            String dDir = sf.format(now);
            String fExt = fileFileName.substring(fileFileName.lastIndexOf("."));
            String savePath = ServletActionContext.getServletContext().getRealPath(this.getSavePath());
            bigurl = savePath+"\"+dDir + fExt;
            try {
                File f = this.getFile();
                FileInputStream inputStream = new FileInputStream(f);
                FileOutputStream outputStream = new FileOutputStream(bigurl);
                byte[] buf = new byte[1024];
                int length = 0;
                while ((length = inputStream.read(buf)) != -1) {
                    outputStream.write(buf, 0, length);
                }
                inputStream.close();
                outputStream.flush();
                outputStream.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
            
            //直接是字符串前面就可以接收到,要是跟下面注释一样转换成json前面还要转换,我试过这样可以直接在前面js中response得到,
            obj =bigurl.substring(bigurl.lastIndexOf("fileResources")) ;    
    //        System.out.println(""success":true,"url":""+dDir+"/"+fExt+"","bigurl":""+bigurl+""");
    //        JSONObject jsonobj = JSONObject.fromObject(path);
    //        obj = jsonobj.toString();
    
            return SUCCESS;
        }
    
        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 getSavePath() {
            return savePath;
        }
    
        public void setSavePath(String savePath) {
            this.savePath = savePath;
        }
    
        public String getObj() {
            return obj;
        }
    
        public void setObj(String obj) {
            this.obj = obj;
        }
    }

    至于传图片路径和图片标题到后台,得到并保存,就是淡出的struts2后台处理,就没必要贴出来了,

    struts.xml中配置这个Action

    <action name="uploadAction" class="com.gt.***.action.UploadAction" >
        <param name="savePath">/fileResources/imageFile</param>
        <result name="success" type="json">
            <param name="contentType">
                text/html
            </param>            
        </result>
    </action>

    至于为什么param是这样的,我没仔细深究,如果有朋友知道麻烦告诉我,谢谢。

    另外ajaxfileupload.js插件很好获得,百度一下你就可以哈哈。

     

  • 相关阅读:
    __init__.py文件的作用
    is is not == !=之间的区别
    使用七牛上传头像
    flask的request的用法
    Mac各个文件夹表示的意思
    sqlalchemy的基本的使用
    将Cygwin Emacs设为Windows explorer默认打开程序
    使用Stardict命令行版本sdcv
    坚持使用GNU/Linux
    在Windows上创建同样的Linux操作环境
  • 原文地址:https://www.cnblogs.com/2589-spark/p/3796205.html
Copyright © 2011-2022 走看看