js上传图片到七牛云存储
时间:2019-08-19
本文章向大家介绍js上传图片到七牛云存储,主要包括js上传图片到七牛云存储使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
项目开发过程中遇到一个需求,运营人员需要上传图片到七牛云,最开始的做法是,后台对接七牛,然后出一个接口,前端调用接口,先将图片传到后台,然后后台再上传七牛云,用的过程中发现,图片小的情况下还好,图片一旦到了几十兆甚至几百兆的时候就很慢,前端上传图片到后台需要一定时间,后端上传到七牛又需要一段时间,很是麻烦,所以果断改成了前端直接上传七牛,直接上代码
<!doctype html> <html lang="zh"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>js上传图片到七牛</title> <style> #container{ width:200px; height:200px; border:1px solid #9d9d9d; border-radius: 6px; margin:50px auto; position: relative; overflow: hidden; } .upload-progress{ width:100%; height:100%; position: absolute; top:0; left:0; background: rgba(0,0,0,0.5); z-index: 5; color:#fff; line-height: 200px; text-align: center; display: none; } #uploadImage{ width:100%; height:100%; position: absolute; top:0; left:0; z-index: 2; text-align: center; line-height: 200px; cursor: pointer; } #container img{ width:100%; position: absolute; top:0; left:0; z-index: 1; } </style> </head> <body> <div id="container"> <div id="uploadImage">选择文件</div> <div class="upload-progress"></div> </div> <script src="/moxie.js"></script> <script src="/plupload.min.js"></script> <script src="/qiniu.js"></script> <script> var uploader = Qiniu.uploader({ disable_statistics_report: false, // 禁止自动发送上传统计信息到七牛,默认允许发送 runtimes: 'html5,flash,html4', // 上传模式,依次退化 browse_button: 'uploadImage', // 上传选择的点选按钮,必需 container: 'container', // 上传区域DOM ID,默认是browser_button的父元素 max_file_size: '100mb', // 最大文件体积限制 flash_swf_url: 'Moxie.swf', // 引入flash,相对路径 dragdrop: false, // 关闭可拖曳上传 chunk_size: '4mb', // 分块上传时,每块的体积 multi_selection: !(moxie.core.utils.Env.OS.toLowerCase() === "ios"), uptoken_url: 'XXX', // 在初始化时,uptoken,uptoken_url,uptoken_func三个参数中必须有一个被设置,uptoken是上传凭证,由其他程序生成;uptoken_url是提供了获取上传凭证的地址,如果需要定制获取uptoken的过程则可以设置uptoken_func;其优先级为uptoken > uptoken_url > uptoken_func domain: 'XXX', // bucket域名,下载资源时用到,必需 get_new_uptoken: true, // 设置上传文件的时候是否每次都重新获取新的uptoken auto_start: true, // 选择文件后自动上传,若关闭需要自己绑定事件触发上传 max_retries: 3, // 上传失败最大重试次数 save_key: true, resize: { // 想限制上传图片尺寸,直接用resize这个属性 width: 300, height: 300 }, init: { 'FilesAdded': function(up, files) { // 文件添加进队列后,处理相关的事情 plupload.each(files, function(file) { console.log(file) }); }, 'BeforeUpload': function(up, file) { // 每个文件上传前,处理相关的事情 console.log("开始上传之前"); $(".upload-progress").show(); }, 'UploadProgress': function(up, file) { // 每个文件上传时,处理相关的事情 console.log("上传中"); $(".upload-progress").html("上传进度:"+file.percent + "%"); }, 'FileUploaded': function(up, file, info) { // 每个文件上传成功后,处理相关的事情 console.log("上传成功"); $(".upload-progress").hide(); var img = new Image(); //创建一个Image对象,实现图片的预下载 img.src = "http://qiniu.com/"+res.key; $("#container").append(img); }, 'Error': function(up, err, errTip) { console.log("上传出错") }, 'UploadComplete': function() { //队列文件处理完毕后,处理相关的事情 } } }); </script> </body> </html>
需要注意的是:
1、这个uploader初始化的时候如果放在change事件中是不会执行的
2、分块上传时,一些分辨率或者色彩密度较高的图片不支持切片
3、点击选择文件之后函数不执行的原因可能有:1)browse_button和container的值写成了class,但是不支持class,需要改成id名;2)函数没有初始化;3)后台返回来的token字段不正确,如果是这个原因,可以尝试将token改为uptoken
最后附上七牛官方的上传demo
1、这个uploader初始化的时候如果放在change事件中是不会执行的
2、分块上传时,一些分辨率或者色彩密度较高的图片不支持切片
3、点击选择文件之后函数不执行的原因可能有:1)browse_button和container的值写成了class,但是不支持class,需要改成id名;2)函数没有初始化;3)后台返回来的token字段不正确,如果是这个原因,可以尝试将token改为uptoken
最后附上七牛官方的上传demo
作者:Eternal丶
链接:https://www.jianshu.com/p/1e53415afb09
原文地址:https://www.cnblogs.com/yehuisir/p/11379538.html
- 如何在silverlihgt中使用右键
- WCF技术剖析之十二:数据契约(Data Contract)和数据契约序列化器(DataContractSerializer)
- silverlight向服务器post数据类
- WCF技术剖析之十三:序列化过程中的已知类型(Known Type)
- 44 Amazing Silverlight 2.0 Screencasts
- CaseStudy(showcase)类库篇-用agTweener来实现动画效果
- CaseStudy(showcase)数据篇-Loading的制作
- CaseStudy(showcase)数据篇-加载图片
- CaseStudy(showcase)数据篇-从XML中获取数据
- CaseStudy(showcase)布局篇-全屏效果
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(12)-系统日志和异常的处理②
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(14)-EasyUI缺陷修复与扩展
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(10)-系统菜单栏[附源码]
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(8)-MVC与EasyUI DataGrid 分页
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Hive排序函数
- Flutter基础widgets教程-CupertinoPageScaffold篇
- 前后端分离开发跨域问题
- Python 常用的工具包(后期继续完善)
- Flutter基础widgets教程-CupertinoSlider篇
- Python学习笔记(五) requets多种请求参数
- java实现多个网络文件批量下载并压缩
- Python学习笔记(四) 爬取网站数据(静态,动态)
- java整合FastDFS文件服务器
- Flutter基础widgets教程-CupertinoSwitch篇
- XmlRootElement的作用和用法
- 获取指定月份的所有工作日(工作日为自定义的)
- 自定义配置类,读取Application.properties中的参数
- 将InputSteram转换成文件输出并下载至本地
- sql serve2008是否自带互斥锁