iView文件上传(OSS直传)

2024-01-08 07:48
文章标签 oss 上传 iview 直传

本文主要是介绍iView文件上传(OSS直传),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

前期项目中使用了第三方的开源UI框架 View UI(前期叫 iView)。总体感觉该UI框架还是比较不错的。但是现在View UI商业化了,部分功能需要付费才能使用。近期做的功能模块需要上传文件,就想到UI中的Upload上传 模块,思前想后决定用它来实现文件上传。
之所以选用UI自身的文件上传,主要是因为其可配置,还有上传进度条。本次文件上传因为要涉及到大文件上传,上传等待时间有点长,为了实时显示上传的进度,故采用Upload上传,其自身带有可配置的上传进度条以及上传文件列表,正好可以满足我的需求。

需求:

此次文件上传需要直传递(OSS)到阿里云服务器。但是官方给的实例中,没有涉及到OSS文件上传的相关配置,为了达到实现OSS直传的目的,现借助已有案例Demo来进一步的改写,实现upload上传文件到阿里云服务器。

<Form ref="voteForm" :model="voteForm" :label-width="120"><FormItem label="上传附件"><!-- 附件链接地址 --><input type="hidden" v-model.trim="voteForm.filePath" /><!-- Upload上传 --><Upload :disabled="loading" :action="upAction" :data="upData" :format="upFormat" :before-upload="beforeUpload":on-success="onSuccess" :on-error="onError" :on-remove="onRemove" :on-format-error="onFormatError":default-file-list="defaultFile"><Button type="primary" icon="ios-cloud-upload-outline" :loading="loading">{{ loading ? "上传中..." : "上传附件" }}</Button></Upload><!-- 提示文字 --><p style="color:red;">温馨提示:请上传指定文件格式的文件!</p></FormItem>
</Form>
参数配置详情:
属性说明类型默认值
action上传的地址,必填String-
disabled是否禁用Booleanfalse
data上传时附带的额外参数Object-
name上传的文件字段名Stringfile
show-upload-list是否显示已上传文件列表Booleantrue
type上传控件的类型,可选值为 select(点击选择),drag(支持拖拽)Stringselect
accept接受上传的文件类型String-
format支持的文件类型,与 accept 不同的是,format 是识别文件的后缀名,accept 为 input 标签原生的 accept 属性,会在选择文件时过滤,可以两者结合使用Array[]
before-upload上传文件之前的钩子,参数为上传的文件,若返回 false 或者 Promise 则停止上传Function-
on-success文件上传成功时的钩子,返回字段为 response, file, fileListFunction-
on-error文件上传失败时的钩子,返回字段为 error, file, fileListFunction-
on-remove文件列表移除文件时的钩子,返回字段为 file, fileListFunction-
on-format-error文件格式验证失败时的钩子,返回字段为 file, fileListFunction-
on-exceeded-size文件超出指定大小限制时的钩子,返回字段为 file, fileListFunction-
default-file-list默认已上传的文件列表,例如:[{name: '',url: ''}]Array[]
【 oss.js 】文件:
const oss = {accessKeyId: "" /* 用户请求的accessid */ ,accessKeySecret: "" /*  */ ,signature: "" /* 上传文件签名信息 */ ,policy: "" /* 用户表单上传策略 */ ,path: "https://xxxxxx.oss-cn-beijing.aliyuncs.com" /* 上传阿里云服务器地址 */ ,filePath: "oss_file/" /* OSS上传文件的路径(生成指定的文件夹) */
};/* 文件重命名 */
const fileRename = fileName => {let suffixName = fileName;if (fileName.lastIndexOf(".") != -1) {suffixName = fileName.substring(fileName.lastIndexOf("."));}const moment = new Date();let yyyy = moment.getFullYear(),MM = moment.getMonth() + 1,dd = moment.getDate(),hh = moment.getHours(),mm = moment.getMinutes(),ss = moment.getSeconds();MM = MM <= 9 ? "0" + MM : MM;dd = dd <= 9 ? "0" + dd : dd;let rm = (Math.random() * 1e5).toFixed(),path = `${yyyy}${MM}/${dd}_${hh}${mm}${ss}_${rm}`;return path + suffixName;
};export { oss, fileRename };

:提出全局公用的属性和方法。

上传文件属性配置:
import { oss, fileRename } from "../utils/oss";export default {name: "Upload",data() {return {loading: false,defaultFile: [] /* { name: "", url: "" } */ ,upAction: oss.path /* 上传路径 */ ,upData: {key: "" /* 文件路径/文件名 */ ,policy: "",OSSAccessKeyId: "",success_action_status: 200 /* 状态码 */ ,signature: "",name: "" /* 文件名 */} /* 上传参数 */ ,upFormat: ["jpg", "jpeg", "png"] /* 上传文件类型 */ ,voteForm: {} /* form表单 */ ,};},methods: {// 上传文件之前beforeUpload(file) {/* 文件重命名 */let fileName = fileRename(String(file.name));// 值传参数let {accessKeyId,policy,signature,filePath} = oss;Object.assign(this.upData, {key: filePath[0] + fileName,policy: policy,OSSAccessKeyId: accessKeyId,signature: signature,name: fileName});this.loading = true;},// 上传成功回调onSuccess(response, file, fileList) {this.loading = false;// 拼接成完整的地址let fileURI = this.upAction + "/" + this.upData.key;this.voteForm.filePath = fileURI;console.log("生成文件地址:", fileURI);this.$Message.success({background: true,content: "文件上传成功"});},// 移除文件onRemove(file) {this.voteForm.filePath = "";this.$Message.success({background: true,content: "附件移除成功"});},// 文件上传失败onError(error, file) {this.loading = false;this.$Message.error({background: true,content: "文件上传失败,请稍后再试!"});},// 文件格式上传失败onFormatError(file) {// 上传文件格式与指定文件格式不匹配this.loading = false;this.$Message.error({background: true,content: "上传文件格式有误,请重新选择文件类型!"});}}
};

注意事项:

  1. 此次项目中使用的是单文件上传,如需配置多文件请参考官网API;
  2. 动态拼接上传参数时需要提前给属性赋默认值,在 beforeUpload 钩子函数中做拦截处理;
  3. 在上传文件之前获取OSS直传其它参数,进行赋值处理,否则上传文件的参数只会展示一个默认的值 file
  4. beforeUpload函数中,若返回 false或者 Promise均会停止文件上传;
  5. OSS直传时 onSuccess 回调函数中 response 返回值 有可能为空,此时需要自己手动拼接上传文件的绝对地址来进行赋值。

这篇关于iView文件上传(OSS直传)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-

在SSH的基础上使用jquery.uploadify.js上传文件

在SSH框架的基础上,使用jquery.uploadify.js实现文件的上传,之前搞了好几天,都上传不了, 在Action那边File接收到的总是为null, 为了这个还上网搜了好多相关的信息,但都不行,最后还是搜到一篇文章帮助到我了,希望能帮助到为之困扰的人。 jsp页面的关键代码: <link rel="stylesheet" type="text/css" href="${page

【CTF Web】BUUCTF Upload-Labs-Linux Pass-13 Writeup(文件上传+PHP+文件包含漏洞+PNG图片马)

Upload-Labs-Linux 1 点击部署靶机。 简介 upload-labs是一个使用php语言编写的,专门收集渗透测试和CTF中遇到的各种上传漏洞的靶场。旨在帮助大家对上传漏洞有一个全面的了解。目前一共20关,每一关都包含着不同上传方式。 注意 1.每一关没有固定的通关方法,大家不要自限思维! 2.本项目提供的writeup只是起一个参考作用,希望大家可以分享出自己的通关思路

Vue3上传图片报错:Current request is not a multipart request

当你看到错误 "Current request is not a multipart request" 时,这通常意味着你的服务器或后端代码期望接收一个 multipart/form-data 类型的请求,但实际上并没有收到这样的请求。在使用 <el-upload> 组件时,如果你已经设置了 http-request 属性来自定义上传行为,并且遇到了这个错误,可能是因为你在发送请求时没有正确地设置

OpenStack:Glance共享与上传、Nova操作选项解释、Cinder操作技巧

目录 Glance member task Nova lock shelve rescue Cinder manage local-attach transfer backup-export 总结 原作者:int32bit,参考内容 从2013年开始折腾OpenStack也有好几年的时间了。在使用过程中,我发现有很多很有用的操作,但是却很少被提及。这里我暂不直接

使用http-request 属性替代action绑定上传URL

在 Element UI 的 <el-upload> 组件中,如果你需要为上传的 HTTP 请求添加自定义的请求头(例如,为了通过身份验证或满足服务器端的特定要求),你不能直接在 <el-upload> 组件的属性中设置这些请求头。但是,你可以通过 http-request 属性来自定义上传的行为,包括设置请求头。 http-request 属性允许你完全控制上传的行为,包括如何构建请求、发送请

Vue3图片上传报错:Required part ‘file‘ is not present.

错误 "Required part 'file' is not present" 通常表明服务器期望在接收到的 multipart/form-data 请求中找到一个名为 file 的部分(即文件字段),但实际上没有找到。这可能是因为以下几个原因: 请求体构建不正确:在发送请求时,可能没有正确地将文件添加到 FormData 对象中,或者使用了错误的字段名。 前端代码错误:在前端代码中,可能

aliyun图片存储OSS工具类

pom.xml配置jar包 <!-- oss --><dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.17.4</version></dependency> yml配置相关key #oss 配置oss:#AKaccessKey: accessKey

【SpringMVC学习06】SpringMVC中实现文件上传

1. 环境准备 springmvc上传文件的功能需要两个jar包的支持,如下 2. 单个文件的上传 2.1 前台页面 简单的写一下前台页面,注意一点的是form表单中别忘了写enctype=”multipart/form-data”属性: <tr><td>商品图片</td><td><c:if test="${itemsCustom.pic !=null}"><img src="/f

使用Vant Uploader 文件上传,后端java中MultipartFile接收不到文件问题解决

问题 在Uploader组件 after-read回调函数将获取的file对象上传到服务器。 <van-uploader:after-read="uploadFile"/>uploadFile(file) {const data = new FormData();data.