阿里云oss js前端获取签名直传文件

2023-11-26 21:40

本文主要是介绍阿里云oss js前端获取签名直传文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 原来的官方文档是先选择文件,再点击上传按钮,上传文件,我这里是选择完文件,就上传,这里主要是在FilesAdded这个里面添加完文件,立刻初始化一次set_upload_param(uploader, '', true); 就能选择完就上传了.

2.这个只是个简单的图片上传,没有用到<input>这个属性来选择文件,,好像用  plupload  里面的属性  browse_button  来选择文件的,我同事用其他插件来上传文件,

  这里有个坑,就是你那个<input   name="file">,就是你的选择文件的input的name属性必须是file,否者会出现IncorrectNumberOfFilesInPOSTRequest 错误,好坑.

3. 这个地址是阿里云源码来的,AppPostPolicyServer是签名的java项目,ss-h5-upload-js-php文件夹里面是前端直传,具体自己下载看看或者去官方下载也可以.我就是

    根据这两个文件夹的东西来修该出我下面的代码的.其他就需要你看官方文档了.

   http://download.csdn.net/download/hch15112345824/10121664

  这个是我文件上传的最后想要的效果图,点击上传图片,选择完图片,直接文件上传到阿里云,然后显示URL,图片的地方也显示上传的图片.


jsp的代码如下:

                            <!-- 阿里云上传 --><div id="container" class="dl-horizontal form-group"><a id="selectfiles" href="javascript:void(0);" class="btn btn-circle btn-success" data-style="expand-left" data-spinner-color="#333">上传图片</a><a id="postfiles" href="javascript:void(0);"></a></div><!-- 这个显示进度的 -->	<div id="ossfile"></div>																			                          </div>  

js的代码如下:

// id.
accessid = ''
// 秘钥.
accesskey = ''
// host: 指的是用户要往哪个域名发往上传请求   host+文件名就是下载路径了.
host = ''
// policy:指的是用户表单上传的策略policy,是经过base64编码过的字符串.
// 加密.
policyBase64 = ''
// signature:是对上述第三个变量policy签名后的字符串.
signature = ''
// 返回的body.
callbackbody = ''
// 文件的名字.	
filename = ''
key = ''
// 过期时间.
expire = 0
// 文件名字.
g_object_name = ''
// 文件类型. local_name
g_object_name_type = 'random_name'
now = timestamp = Date.parse(new Date()) / 1000; 
// 这个是获取accessid policy signature dir host expire.
function send_request()
{var xmlhttp = null;if (window.XMLHttpRequest){xmlhttp=new XMLHttpRequest();}else if (window.ActiveXObject){xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");}if (xmlhttp!=null){serverUrl = ctx + '/aliyun/getPolicy';xmlhttp.open( "GET", serverUrl, false );xmlhttp.send( null );return xmlhttp.responseText;}else{alert("您的浏览器不支持XMLHTTP,请换浏览器登录再使用.");}
};function get_signature()
{// 可以判断当前expire是否超过了当前时间,如果超过了当前时间,就重新取一下.3s 做为缓冲.now = timestamp = Date.parse(new Date()) / 1000; if (expire < now + 3){body = send_request()var obj = eval ("(" + body + ")");host = obj['host']policyBase64 = obj['policy']accessid = obj['accessid']signature = obj['signature']expire = parseInt(obj['expire'])callbackbody = obj['callback'] key = obj['dir']return true;}return false;
};// 截取文件的后缀.
function get_suffix(filename) {pos = filename.lastIndexOf('.')suffix = ''if (pos != -1) {suffix = filename.substring(pos)}return suffix;
}// 上传的时候文件保存路径和名称:我这里是 文件夹+uuid+文件后缀.
function calculate_object_name(filename)
{if (g_object_name_type == 'local_name'){g_object_name += "${filename}"}else if (g_object_name_type == 'random_name'){var uuid = generateUUID();suffix = get_suffix(filename);g_object_name = key + uuid + suffix;}return ''
}//初始化一些参数.
function set_upload_param(up, filename, ret)
{if (ret == false){ret = get_signature()}g_object_name = key;if (filename != '') {suffix = get_suffix(filename)calculate_object_name(filename)}new_multipart_params = {'key' : g_object_name,'policy': policyBase64,'OSSAccessKeyId': accessid, 'success_action_status' : '200', // 让服务端返回200,不然,默认会返回204.'callback' : callbackbody,'signature': signature,};up.setOption({'url': host,'multipart_params': new_multipart_params});up.start();
}// 这里是官方原来的文档代码,集体如下.
var uploader = new plupload.Uploader({runtimes : 'html5,flash,silverlight,html4',browse_button : 'selectfiles', container: document.getElementById('container'),flash_swf_url : 'static/aliyunUpload/Moxie.swf',silverlight_xap_url : 'static/aliyunUpload/Moxie.xap',url : 'http://oss.aliyuncs.com',multi_selection : false,filters: {mime_types : [ // 只允许上传图片和zip,rar文件.{ title : "Image files", extensions : "jpg,gif,png,bmp" }],max_file_size : '10mb', // 最大只能上传10mb的文件.prevent_duplicates : true // 不允许选取重复文件.},init: {FilesAdded: function(up, files) {plupload.each(files, function(file) {document.getElementById('ossfile').innerHTML += '<div id="' + file.id + '">' + file.name + ' (' + plupload.formatSize(file.size) + ')<b></b>'+'<div class="progress"><div class="progress-bar" style="width: 0%"></div></div>'+'</div>';});set_upload_param(uploader, '', true);},BeforeUpload: function(up, file) {set_upload_param(up, file.name, false);},UploadProgress: function(up, file) {var d = document.getElementById(file.id);d.getElementsByTagName('b')[0].innerHTML = '<span>' + file.percent + "%</span>";var prog = d.getElementsByTagName('div')[0];var progBar = prog.getElementsByTagName('div')[0]progBar.style.width= 2*file.percent+'px';progBar.setAttribute('aria-valuenow', file.percent);},FileUploaded: function(up, file, info) {uploader.removeFile(file);var imgDir = host+g_object_name;var title = file.name;if (info.status == 200) {$.ajax({url: ctx + '/advertisement/aliUpload',type:"post",async: false,data:{"imgDir" : imgDir,"productId" : productId,"title" : title},dataType:"json",success: function (data) {if(data.isSuccess == '1'){$("#imgDir").val(data.imgDir);$("#imgView").attr('src', data.imgDir);// 删除进度条信息.$("div#"+file.id).remove();}else{alert("保存信息失败,请重新上传文件.");delFileList();}},error: function (data, textStatus) {alert("上传失败,请检查网络之后重新上传.");delFileList();}});} else {alert("上传失败,请检查网络之后重新上传.");delFileList();} },Error: function(up, err) {if (err.code == -600) {alert("选择的文件太大了,重新选择文件.");}else if (err.code == -601) {alert("选择的文件后缀不对,重新选择文件.");}else if (err.code == -602) {alert("这个文件已经上传过一遍了或者已存在上传队列面,请确认再上传.");}else {alert("上传出现错误,请稍后再试.");console.log(err);console.log(up);}delFileList();}}
});// 出错删除上传队列重新上传.
function delFileList(){document.getElementById('ossfile').innerHTML="";uploader.splice(0,9999);
}// 获取uuid.
function generateUUID() {var d = new Date().getTime();var uuid = 'xxxxxxxxxxxx4xxxyxxxxxxxxxxxxxxx'.replace(/[xy]/g, function(c) {var r = (d + Math.random()*16)%16 | 0;d = Math.floor(d/16);return (c=='x' ? r : (r&0x3|0x8)).toString(16);});return uuid;
};uploader.init();
















这篇关于阿里云oss js前端获取签名直传文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/426349

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件