百度WebUploader插件上传文件

使用Web Uploader文件上传需要引入三种资源:JS, CSS, SWF。

  • 引入JS文件
<link rel="stylesheet" type="text/css"
    href="${base}/assets/global/plugins/webuploader/webuploader.css" />
  • 引入CSS样式
<script src="${base }/assets/global/plugins/webuploader/webuploader.js" type="text/javascript"></script>
  • 引入SWF,SWF不直接引用,在webUploader初始化的时候指定SWF的路径就可以了。参考后面的代码。

画面比较简单,长这个样子
这里写图片描述
这里写图片描述

  • JS部分
var initWebUploader = function() {
    var $ = jQuery,
    $list = $('#thelist'),
    $btn = $('#ctlBtn'),
    state = 'pending',
    uploader;
    uploader = WebUploader.create({
        // swf文件路径
        swf: ctx + '/assets/global/plugins/webuploader/Uploader.swf',
        // 文件接收服务端。
        server: ctx + '/teach/attend-upload.do',
        // 选择文件的按钮。可选。
        // 内部根据当前运行是创建,可能是input元素,也可能是flash.
        pick: '#picker',
        //设置input的name属性,不设置默认为file
//      fileVal:'upload',
        // 不压缩image, 默认如果是jpeg,文件上传前会压缩一把再上传!
        resize: false
    });
    uploader.on( 'fileQueued', function( file ) {
        addFile(file);
    });
    uploader.on( 'fileDequeued', function( file ) {
        var $li = $('#'+file.id);
        $li.remove();
    });
    // 文件上传过程中创建进度条实时显示。
    uploader.on( 'uploadProgress', function( file, percentage ) {
        var $li = $( '#'+file.id ),
            $percent = $li.find('.progress');

        // 避免重复创建
        if ( !$percent.length ) {
            $percent = $('<div class="progress progress-striped active">' +
              '<div class="progress-bar" role="progressbar" style="width: 0%">' +
              '</div>' +
            '</div>').appendTo( $li ).find('.progress-bar');
        }

        $li.find('td.state').text('上传中');
        $li.find('.progress span').html(parseInt(percentage*100) +"%");
//      $percent.css( 'width', percentage * 100 + '%' );
    });
    uploader.on( 'uploadSuccess', function( file,response ) {
        if(response.result == "文件过大!") {
            $( '#'+file.id ).find('td.state').text('文件过大');
        }
        if(response.result == "上传成功!") {
             $( '#'+file.id ).find('td.state').text('已上传');
             //上传成功延迟两秒后关闭
             setTimeout(function () {uploader.removeFile( file )}, 2000);
        }
    });

    uploader.on( 'uploadError', function( file,reason ) {
        $( '#'+file.id ).find('td.state').text('上传出错');
    });

//  uploader.on( 'uploadComplete', function( file ) {
//      $( '#'+file.id ).find('.progress').fadeOut();
//  });

    uploader.on( 'all', function( type ) {
        if ( type === 'startUpload' ) {
            state = 'uploading';
        } else if ( type === 'stopUpload' ) {
            state = 'paused';
        } else if ( type === 'uploadFinished' ) {
            state = 'done';
        }

        if ( state === 'uploading' ) {
            $btn.text('暂停上传');
        } else {
            $btn.text('开始上传');
        }
    });
    $btn.on( 'click', function() {
        if ( state === 'uploading' ) {
            uploader.stop();
        } else {
            uploader.upload();
        }
    });
    function addFile(file) {
         var $li = $( '<tr id="' + file.id + '">' +
                    '<td class="info">' + file.name + '</td>' +
                    '<td class="state">等待上传...</td>'+
                    '<td class="progress"><span></span></td>' +
                    '</tr>' ),
                $btns = $('<td class="file-panel">' +
                    '<span class="cancel">删除</span></td>').appendTo( $li );
         $btns.on( 'click', 'span', function() {
            uploader.removeFile( file );
         });
         $li.appendTo( $list);
   }

}
  • Nutz部分upload.js
var ioc = {
    tmpFilePool : {
        type : 'org.nutz.filepool.NutFilePool',
        // 临时文件最大个数为 1000 个
        args : [ "D:/Work/data/log", 1000 ]
    },
    uploadFileContext : {
        type : 'org.nutz.mvc.upload.UploadingContext',
        singleton : false,
        args : [ {
            refer : 'tmpFilePool'
        } ],
        fields : {
            // 是否忽略空文件, 默认为 false
            ignoreNull : true,
            // 单个文件最大尺寸(大约的值,单位为字节,即 1048576 为 1M)
//          maxFileSize : 1048576,
        // 正则表达式匹配可以支持的文件名
        // nameFilter : '^(.+[.])(xls)$'
        }
    },
    myUpload : {
        type : 'org.nutz.mvc.upload.UploadAdaptor',
        singleton : false,
        args : [ {
            refer : 'uploadFileContext'
        } ]
    }
};
  • Nutz部分Module
@At("/teach/attend-upload")
    @AdaptBy(type = UploadAdaptor.class, args = { "ioc:myUpload" })
    @Ok("raw:json")
    public String uploadFile(@Param("file")TempFile tf){
        return attendService.uploadFile(tf);
    }
  • attendService的uploadFile方法
public String uploadFile(TempFile tf) {
        Map<String, Object> map = new HashMap<>();
        if(tf.getSize() >= 62914560) {
             map.put( "result", "文件过大!" );
                return Json.toJson( map );
        }
        UploadFile uf = new UploadFile();
        if(tf == null || "".equals( tf ) ){
            map.put( "result", "上传失败!" );
            return Json.toJson( map );
        }
        try {
            System.out.println(tf.getSubmittedFileName());
            System.out.println(tf.getSize());
            String[] postfix = tf.getSubmittedFileName().split("\\.");
            String path = "D:\\data\\user\\";
            File temp = new File( path );
            if(!temp.exists()){
                temp.mkdirs();
            }
            System.out.println(temp.getPath());
            System.out.println(postfix[postfix.length - 2]);
            System.out.println(postfix[postfix.length - 1]);
            tf.write( temp.getPath() + "\\"  + postfix[postfix.length - 2] + "." + postfix[postfix.length - 1]);
            uf.setNewFileName(temp.getPath() + "\\"  + postfix[postfix.length - 2] + "." + postfix[postfix.length - 1]);
            uf.setOldFileName(tf.getSubmittedFileName());
            dao().insert(uf);
            tf.delete();
            map.put( "result", "上传成功!" );
        }
        catch( Exception e ) {
            e.printStackTrace();
            map.put( "result", "上传失败!" );
        }
        return Json.toJson( map );
    }
  • 上传成功图片
    这里写图片描述
    这里写图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ezreal_geng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值