前端上传图片到oss服务,模仿微博多张图片上传(最多九张)

2023-11-02 10:50

本文主要是介绍前端上传图片到oss服务,模仿微博多张图片上传(最多九张),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果图如下
在这里插入图片描述

在这里插入图片描述

核心js文件

  • 推荐《前端上传组件Plupload使用指南》,有较详细使用指南。
  • 文件地址:
https://www.cnblogs.com/2050/p/3913184.html#plupload_doc4
首先是css文件的引入
  • 上传组件的css
  <link rel="stylesheet" href='../css/uploadOss.css'/>

-引入jq和upload 核心js文件

<script src="../js/commonJs/jquery.min.js"></script>
<script type="text/javascript" src="../js/commonJs/plupload.full.min.js"></script>

-html结构(具体细节图按照各位ui公司的图进行页面和样式开发,在这只介绍使用用法)

<a href="###" class="gc_tp"><em class="tellbox_tp"></em>图片<input type="file" id="choose_pic_click_1" name="file" multiple="multiple"  onmousedown="mouseDown_check(this)" accept="image/*"></a>
//发布传参
var pic_list = [];
var pushStr = '';
var publicParams = {};
publicParams.u = $.cookie('uid');//uid
publicParams.text = '';         //消息文本   注意替换一下游戏
publicParams.title = '说点什么来记录今天';    //消息标题   说点什么来记录今天
publicParams.pic = '';          //消息图片
publicParams.video = '';        //消息视频
publicParams.video_cover = '';  //视频封面
publicParams.video_title = '';	//视频标题
publicParams.f_type = 1;        //消息来源类型 int
publicParams.visible = 0;     //消息可见性
//公用部分
var accessid = '';
var accesskey = '';
var host = '';
var policyBase64 = '';
var signature = '';
var callbackbody = '';
var filename = '';
var key = '';
var expire = 0;
var g_object_name = '';
var g_object_name_type = '';
var now = timestamp = Date.parse(new Date()) / 1000;//增加参数
var video_face;//视频封面的文件存储
function send_request_video() {var xmlhttp = null;if (window.XMLHttpRequest) {xmlhttp = new XMLHttpRequest();}else if (window.ActiveXObject) {xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");}if (xmlhttp != null) {serverUrl = '换成你自己的请求地址';//第一次请求地址xmlhttp.open("POST", serverUrl, false);xmlhttp.send(null);return xmlhttp.responseText}else {alert("Your browser does not support XMLHTTP.");}
}
//图片上传
function send_request_pic() {var xmlhttp = null;if (window.XMLHttpRequest) {xmlhttp = new XMLHttpRequest();}else if (window.ActiveXObject) {xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");}if (xmlhttp != null) {serverUrl = '换成你自己的请求地址';//第一次请求地址xmlhttp.open("POST", serverUrl, false);xmlhttp.send(null);return xmlhttp.responseText}else {alert("Your browser does not support XMLHTTP.");}
}function check_object_radio() {var tt = document.getElementsByName('myradio');for (var i = 0; i < tt.length; i++) {if (tt[i].checked) {g_object_name_type = tt[i].value;break;}}
}function get_signature() {//可以判断当前expire是否超过了当前时间,如果超过了当前时间,就重新取一下.3s 做为缓冲now = timestamp = Date.parse(new Date()) / 1000;if (expire < now + 3) {body = send_request_video();body = JSON.parse(body);//console.log(body, body.Result);var obj = eval("(" + body.Result + ")");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_signature_pic() {//可以判断当前expire是否超过了当前时间,如果超过了当前时间,就重新取一下.3s 做为缓冲now = timestamp = Date.parse(new Date()) / 1000;if (expire < now + 3) {body = send_request_pic();body = JSON.parse(body);var obj = eval("(" + body.Result + ")");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 random_string(len) {len = len || 32;var chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';var maxPos = chars.length;var pwd = '';for (i = 0; i < len; i++) {pwd += chars.charAt(Math.floor(Math.random() * maxPos));}return pwd;
}function get_suffix(filename) {pos = filename.lastIndexOf('.');suffix = '';if (pos != -1) {suffix = filename.substring(pos)}return suffix;
}function calculate_object_name(filename, is_set_w_h, w, h) {if (g_object_name_type == 'local_name') {g_object_name += "${filename}";}else if (g_object_name_type == 'random_name') {suffix = get_suffix(filename);var re_key = key + random_string(32);if (is_set_w_h) {re_key += "|" + w + "|" + h;}g_object_name = re_key + suffix;}return ''
}function get_uploaded_object_name(filename) {if (g_object_name_type == 'local_name') {tmp_name = g_object_name;tmp_name = tmp_name.replace("${filename}", filename);return tmp_name}else if (g_object_name_type == 'random_name') {return g_object_name}
}
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();
}function set_upload_param_pic(up, filename, ret) {if (ret == false) {ret = get_signature_pic();}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();
}function mouseDown_check(node) {if ($('#content').css('display') == 'block') {layer.open({title: '提示',content: '确定放弃上传视频吗?',yes: function (index) {layer.close(index);close_();}});} else {$('#choose_pic_click_1').click();}
}var uploader_pic = new plupload.Uploader({runtimes: 'html5,flash,silverlight,html4',browse_button: ["choose_pic_click_1", "choose_pic_click"],multi_selection: true,//上传多个flash_swf_url: 'lib/plupload-2.1.2/js/Moxie.swf',silverlight_xap_url: 'lib/plupload-2.1.2/js/Moxie.xap',url: 'http://oss.aliyuncs.com',filters: {mime_types: [ //只允许上传图片和zip文件{title: "Image files", extensions: "jpg,gif,png,bmp"},],
//            mime_types: [],max_file_size: '10mb', //最大只能上传10mb的文件prevent_duplicates: true //不允许选取重复文件},init: {PostInit: function () {document.getElementById('ossfile').innerHTML = '';},FilesAdded: function (up, files) {if ($('.tp_fatherBox').css('display') == 'none') {number_canUp();$('.tp_fatherBox').css('display', 'block');$("#choose_pic_click_1").attr('disabled', 'disabled');} else {$("#choose_pic_click_1").removeAttr('disabled');}if (files.length > $("#can_upNumber").html()) {layer.open({title: '提示',content: '超过了可添加数量!'});up.files = '';up.total.reset();return} else {var strs = '';plupload.each(files, function (file) {strs += '<div class="contribute_choosePicLi"  id="' + file.id + '"><span class="picbg"></span><span class="contribute_delete" onclick=\'delete_pic("' + file.id + '")\'></span><img  class="choose_pic"><div class="progress"><div class="progress-bar" style="width: 0%"></div></div></div>';});$("#listPic").append(strs);set_upload_param_pic(up, '', false);}},BeforeUpload: function (up, file) {check_object_radio();set_upload_param_pic(up, file.name, true);//var w = 0, h = 0;//var MyTest = file.getNative();//var reader = new FileReader();//reader.readAsDataURL(MyTest);//reader.onload = function (theFile) {//    var image = new Image();//    image.src = theFile.target.result;//    image.onload = function () {//        w = this.width;//        h = this.height;//    };//};////set_upload_param_pic(up, file.name, true, true, w, h);},UploadProgress: function (up, file) {var d = $("#listPic").find('div#' + file.id);var prog = d.find('div').eq(0);var progBar = d.find('div').eq(0);progBar.css('width', '100%');progBar.attr('aria-valuenow', file.percent);number_canUp();},FileUploaded: function (up, file, info) {number_canUp();if (info.status == 200) {var self_info = JSON.parse(info.response).Result;pic_list.push(self_info.name + '$' + self_info.width + '$' + self_info.height);$('#' + file.id).find('img').attr('src', self_info.name);$('#' + file.id).find('div.progress').css('display', 'none');
//                    document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = 'upload to oss success, object name:' + get_uploaded_object_name(file.name) + '回调服务器返回的内容是:' + info.response;}else if (info.status == 203) {layer.open({title: '提示',content: '上传到OSS成功,但是oss访问用户设置的上传回调服务器失败,失败原因是:' + info.response,yes: function (index) {layer.close(index);}});}else {layer.open({title: '提示',content: info.response,yes: function (index) {layer.close(index);}});}},UploadComplete: function (up, file) {},Error: function (up, err) {if (err.code == -600) {layer.msg('选择的文件太大了,可以根据应用情况,在upload.js 设置一下上传的最大大小', {time: 600});}else if (err.code == -601) {layer.msg('选择的文件后缀不对,可以根据应用情况,在upload.js进行设置可允许的上传文件类型', {time: 600});}else if (err.code == -602) {layer.msg('这个文件已经上传过一遍了', {time: 600});}else {layer.msg("Error xml:" + err.response, {time: 800});}}}
});uploader_pic.init();function aa() {alert();var MyTest = document.getElementById("choose_pic_click_1").files[0];var reader = new FileReader();reader.readAsDataURL(MyTest);reader.onload = function (theFile) {var image = new Image();image.src = theFile.target.result;image.onload = function () {alert("图片的宽度为" + this.width + ",长度为" + this.height);};};
}//计算还可以插入几张图片
function number_canUp() {var now_ = $("#listPic").find('div.contribute_choosePicLi').length;$('#can_upNumber').html(Number(9 - now_));
}
function delete_pic(id) {$('#' + id).remove();layer.open({title: '提示',content: '删除成功'});var test2 = document.getElementById('choose_pic_click');test2.value = '';number_canUp();
}
function close_tpFtherbox() {$('#listPic').empty();publicParams.pic = '';pic_list = [];var test = document.getElementById('choose_pic_click_1');var test2 = document.getElementById('choose_pic_click');test.value = '';test2.value = '';$("#choose_pic_click_1").removeAttr('disabled');number_canUp();uploader_pic.files = '';uploader_pic.total.reset();$('.tp_fatherBox').css('display', 'none');
}

这篇关于前端上传图片到oss服务,模仿微博多张图片上传(最多九张)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

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

这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

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

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

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

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

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

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

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo