在七牛上传之后如何自己自定义上传完成处理并在页面显示。

Qiniu 七牛问题解答

很多用户不懂怎么写上传完成后的处理事件。我带大家来写个。

问题解决方案

1,首先要在如下的main.js中做如下的配置修改。

/*global Qiniu */
/*global plupload */
/*global FileProgress */
/*global hljs */

$(function() {
    var uploader = Qiniu.uploader({
        runtimes: ‘html5,flash,html4‘,
        browse_button: ‘pickfiles‘,
        container: ‘container‘,
        drop_element: ‘container‘,
        max_file_size: ‘100mb‘,
        flash_swf_url: ‘js/plupload/Moxie.swf‘,
        dragdrop: true,
        chunk_size: ‘4mb‘,
        uptoken_url: "servlet/responseHandler",
        domain: $(‘#domain‘).val(),
        // downtoken_url: ‘/downtoken‘,
        // unique_names: true,
        // save_key: true,
        // x_vars: {
        //     ‘id‘: ‘1234‘,
        //     ‘time‘: function(up, file) {
        //         var time = (new Date()).getTime();
        //         // do something with ‘time‘
        //         return time;
        //     },
        // },
        auto_start: true,
        init: {
            ‘FilesAdded‘: function(up, files) {
                $(‘table‘).show();
                $(‘#success‘).hide();
                plupload.each(files, function(file) {
                    var progress = new FileProgress(file, ‘fsUploadProgress‘);
                    progress.setStatus("缁?澶?绶?...");
                });
            },
            ‘BeforeUpload‘: function(up, file) {
                var progress = new FileProgress(file, ‘fsUploadProgress‘);
                var chunk_size = plupload.parseSize(this.getOption(‘chunk_size‘));
                if (up.runtime === ‘html5‘ && chunk_size) {
                    progress.setChunkProgess(chunk_size);
                }
            },
            ‘UploadProgress‘: function(up, file) {
                var progress = new FileProgress(file, ‘fsUploadProgress‘);
                var chunk_size = plupload.parseSize(this.getOption(‘chunk_size‘));
                progress.setProgress(file.percent + "%", up.total.bytesPerSec, chunk_size);

            },
            ‘UploadComplete‘: function() {
                $(‘#success‘).show();
               // alert("woaini");
               // var v = 4,
              //  document.getElementById(‘woaini‘).outerHTML = ‘<a>woaini</a>‘;
              //  alert("wobuai");

            },
            ‘FileUploaded‘: function(up, file, info) {
                var progress = new FileProgress(file, ‘fsUploadProgress‘);
                progress.setComplete(up, info);
            },
            ‘Error‘: function(up, err, errTip) {
                $(‘table‘).show();
                var progress = new FileProgress(err.file, ‘fsUploadProgress‘);
                progress.setError();
                progress.setStatus(errTip);
            }
            // ,
            // ‘Key‘: function(up, file) {
            //     var key = "";
            //     // do something with key
            //     return key
            // }
        }
    });

    uploader.bind(‘FileUploaded‘, function() {
        console.log(‘hello man,a file is uploaded‘);
    });
    $(‘#container‘).on(
        ‘dragenter‘,
        function(e) {
            e.preventDefault();
            $(‘#container‘).addClass(‘draging‘);
            e.stopPropagation();
        }
    ).on(‘drop‘, function(e) {
        e.preventDefault();
        $(‘#container‘).removeClass(‘draging‘);
        e.stopPropagation();
    }).on(‘dragleave‘, function(e) {
        e.preventDefault();
        $(‘#container‘).removeClass(‘draging‘);
        e.stopPropagation();
    }).on(‘dragover‘, function(e) {
        e.preventDefault();
        $(‘#container‘).addClass(‘draging‘);
        e.stopPropagation();
    });

    $(‘#show_code‘).on(‘click‘, function() {
        $(‘#myModal-code‘).modal();
        $(‘pre code‘).each(function(i, e) {
            hljs.highlightBlock(e);
        });
    });

    $(‘body‘).on(‘click‘, ‘table button.btn‘, function() {
        $(this).parents(‘tr‘).next().toggle();
    });

    var getRotate = function(url) {
        if (!url) {
            return 0;
        }
        var arr = url.split(‘/‘);
        for (var i = 0, len = arr.length; i < len; i++) {
            if (arr[i] === ‘rotate‘) {
                return parseInt(arr[i + 1], 10);
            }
        }
        return 0;
    };

    $(‘#myModal-img .modal-body-footer‘).find(‘a‘).on(‘click‘, function() {
        var img = $(‘#myModal-img‘).find(‘.modal-body img‘);
        var key = img.data(‘key‘);
        var oldUrl = img.attr(‘src‘);
        var originHeight = parseInt(img.data(‘h‘), 10);
        var fopArr = [];
        var rotate = getRotate(oldUrl);
        if (!$(this).hasClass(‘no-disable-click‘)) {
            $(this).addClass(‘disabled‘).siblings().removeClass(‘disabled‘);
            if ($(this).data(‘imagemogr‘) !== ‘no-rotate‘) {
                fopArr.push({
                    ‘fop‘: ‘imageMogr2‘,
                    ‘auto-orient‘: true,
                    ‘strip‘: true,
                    ‘rotate‘: rotate,
                    ‘format‘: ‘png‘
                });
            }
        } else {
            $(this).siblings().removeClass(‘disabled‘);
            var imageMogr = $(this).data(‘imagemogr‘);
            if (imageMogr === ‘left‘) {
                rotate = rotate - 90 < 0 ? rotate + 270 : rotate - 90;
            } else if (imageMogr === ‘right‘) {
                rotate = rotate + 90 > 360 ? rotate - 270 : rotate + 90;
            }
            fopArr.push({
                ‘fop‘: ‘imageMogr2‘,
                ‘auto-orient‘: true,
                ‘strip‘: true,
                ‘rotate‘: rotate,
                ‘format‘: ‘png‘
            });
        }

        $(‘#myModal-img .modal-body-footer‘).find(‘a.disabled‘).each(function() {

            var watermark = $(this).data(‘watermark‘);
            var imageView = $(this).data(‘imageview‘);
            var imageMogr = $(this).data(‘imagemogr‘);

            if (watermark) {
                fopArr.push({
                    fop: ‘watermark‘,
                    mode: 1,
                    image: ‘http://www.b1.qiniudn.com/images/logo-2.png‘,
                    dissolve: 100,
                    gravity: watermark,
                    dx: 100,
                    dy: 100
                });
            }

            if (imageView) {
                var height;
                switch (imageView) {
                    case ‘large‘:
                        height = originHeight;
                        break;
                    case ‘middle‘:
                        height = originHeight * 0.5;
                        break;
                    case ‘small‘:
                        height = originHeight * 0.1;
                        break;
                    default:
                        height = originHeight;
                        break;
                }
                fopArr.push({
                    fop: ‘imageView2‘,
                    mode: 3,
                    h: parseInt(height, 10),
                    q: 100,
                    format: ‘png‘
                });
            }

            if (imageMogr === ‘no-rotate‘) {
                fopArr.push({
                    ‘fop‘: ‘imageMogr2‘,
                    ‘auto-orient‘: true,
                    ‘strip‘: true,
                    ‘rotate‘: 0,
                    ‘format‘: ‘png‘
                });
            }
        });

        var newUrl = Qiniu.pipeline(fopArr, key);

        var newImg = new Image();
        img.attr(‘src‘, ‘loading.gif‘);
        newImg.onload = function() {
            img.attr(‘src‘, newUrl);
            img.parent(‘a‘).attr(‘href‘, newUrl);
        };
        newImg.src = newUrl;
        return false;
    });

});

2,在如上的代码片中做如下修改:

在标记处添加如下代码,实现在前端显示返回来的图片。(用js来实现前端的控件显示)

     var res = eval("(" + info.toString() + ")");
                alert(res.key);

                var sourceLink = domain + res.key; //获取上传成功后的文件的Url
                alert(sourceLink);
                $("#images").attr("src",sourceLink);
                var input=top.document.getElementById("photo_small");
                input.setAttribute("src",sourceLink);

结果演示

时间: 2024-10-04 22:33:31

在七牛上传之后如何自己自定义上传完成处理并在页面显示。的相关文章

【转】七牛免费SSL证书,配置自定义域名CDN加速

原文链接:https://excaliburhan.com/post/use-qiniu-ssl-and-cdn.html 申请七牛SSL证书 其实,七牛在很早之前就支持CDN使用https,但是他要求证书的有效期是一年及以上,而我的主站用了Let's Encrypt的免费SSL证书,有效期90天,自动续签的形式.所以,为了使CDN的图片也是https的,一直采用了七牛默认的xxx.qnssl.com域名. 在11月,七牛发布了免费SSL证书,亚洲诚信的DV证书.申请起来也很简单,参见七牛SSL

element upload 一次性上传多张图片(包含自定义上传不走action)

最重要的都圈出来了 原文地址:https://www.cnblogs.com/Mr-Rshare/p/10223891.html

UEditor+七牛,实现图片直连上传

最近做的项目,涉及到使用富文本编辑器,我选择了百度的UEditor.同时,我们的图片放在七牛云存储上.关于这两者间的集成,我写下一些个人的经验,与大家分享. 图片上传方案 目前来说,Web端基于七牛等云存储的图片上传方式分为以下两种: 1. 上传图片至服务端,再将数据转发至七牛. 通过服务端接受用户上传的内容,同时可以对内容进行有效性审核,拒绝不合规范的内容,然后从服务端将内容上传至七牛. 这种方法可以有效控制并记录用户提交的内容,但同时也增加了服务器的运行压力. 2. 直接上传图片至七牛,然后

话说android端七牛图片上传

七牛图片上传业务流程如下图(这是官方的图): 由上图可知,要想实现图片上传,是要三端进行交互的(我刚刚开始以为只要七牛服务器跟客户端交互就行) 接下来步骤如下: 1.首先肯定是要有一个七牛的账号,并创建一个空间 2.客户端向业务服务器(也就是客户端的应用服务器)发请求你要上传多上张图片 3.业务服务器根据客户端的请求向七牛云存储生成token(应用的服务器下载好相应的七牛sdk然后根据接口文档所述向七牛服务器请求token,token相当于一把钥匙,具体代码我也不知道怎么实现,毕竟我不是写后台的

nodejs+phantomjs+七牛 实现截屏操作并上传七牛存储

近来研究了下phantomjs,只是初涉,还谈不上深入研究,首先介绍下什么是phantomjs. 官网上的介绍是:”PhantomJS is a headless WebKit scriptable with a JavaScript API. It has fast and native support for various web standards: DOM handling, CSS selector, JSON, Canvas, and SVG.”翻译过来就是:”PhantomJS

ASP.NET Core 简单实现七牛图片上传(FormData 和 Base64)

七牛图片上传 SDK(.NET 版本):https://developer.qiniu.com/kodo/sdk/1237/csharp UpoladService示例代码: public class UpoladService : IUpoladService {     private readonly static string[] _imageExtensions = new string[] { ".jpg", ".png", ".gif&quo

java开发:分享一下百度ueditor和七牛的图片集成上传

做网站时,如果上传的图片量很大,现在不少人会选用七牛图片服务器.那么,今天就来说说如何把网站的图片上传与七牛的sdk集成的问题. jsp页面,实现图片上传的方式也很多,今天就来说下百度的编辑器:ueditor 首先要到官网去下载它,后面我也会附上源代码,需要的朋友可以下载. 我们新建一个项目:qndemo,然后将ueditor放到webroot目录下,截图如下: 另外,我们还要引入jar包: 前台页面,我们需要引用相关js,默认配置下,会加载出编辑效果,如下图: 这时候,我们上传的图片会保存在本

PKPJIB七牛文件上传管理

圭拉镗夯後 PKPJIB七牛文件上传管理

七牛上传视频添加到队列时视频大小是否添加

最近在做视频分析的项目,遇到了一些关于七牛上传视频文件的问题. 当 选择的视频文件 大于 本地剩余空间 时,则取消上传. 'FilesAdded': function(up, files) { plupload.each(files, function(file,index) { //重点在这里 var fileSize=0; for(var i=0;i<files.length;i++){ fileSize+= Math.ceil(files[i].size/1024/1024); }; //