vue 文件上传至服务器_oss文件服务器

vue 文件上传至服务器_oss文件服务器为什么使用对象存储OSS很多企业的文件上传下载都是通过文件流的形式进行上传下载的,需要后端配合,对服务器压力很大,而且高消费,对公司损失太大,我们选择使用oss将尽可能地缩小成本,以及对网站及逆行大幅度提升使用对象存储OSS改变了什么网站数据动静分离,大幅提升网页性能 单独的文件管理界面,管理网站文件和本地电脑一样高效率方便使用 成本低,资源弹性伸缩,按需付费什么是对象存储OSS阿里云对象存储OSS(ObjectStorageService)是一款海量、安全、低成本、高可靠的云存储

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

为什么使用对象存储OSS

很多企业的文件上传下载都是通过文件流的形式进行上传下载的,需要后端配合,对服务器压力很大,而且高消费,对公司损失太大,我们选择使用oss将尽可能地缩小成本,以及对网站及逆行大幅度提升

使用对象存储OSS改变了什么

  1. 网站数据动静分离,大幅提升网页性能
  2. 单独的文件管理界面,管理网站文件和本地电脑一样高效率方便使用
  3. 成本低,资源弹性伸缩,按需付费

什么是对象存储OSS

阿里云对象存储OSS(Object Storage Service)是一款海量、安全、低成本、高可靠的云存储服务,可提供99.9999999999%(12个9)的数据持久性,99.995%的数据可用性。多种存储类型供选择,全面优化存储成本。

在项目中使用

  1. 安装 ali-oss第三方库

    npm install ali-oss --save
    or
    yarn add ali-oss
  2.  在项目中新建一个oss.js文件(用于放置我们的配置项)

    import OSS from 'ali-oss'
    // or
    // const OSS = require('ali-oss')
    
    export const client = new OSS({
        region: 'oss-cn-hangzhou', // oss地址
        accessKeyId: 'xxxxxxxxxxx', // 通过阿里云控制台创建的AccessKey ID。
        accessKeySecret: 'xxxxxxxxxxx', // 通过阿里云控制台创建的AccessKey Secret。
        bucket: 'xxxxxxxxxxx', // 仓库名字
        useFetch: true, // 支持上传大于100KB的文件
        secure:true // 返回的url为https
    })
    
    export const headers = {
        // 指定该Object被下载时网页的缓存行为。
        "Cache-Control": "no-cache",
        // 指定该Object被下载时的名称。
        "Content-Disposition": "inline",
        // 指定该Object被下载时的内容编码格式。
        "Content-Encoding": "UTF-8",
        // 指定过期时间。
        Expires: "Wed, 08 Jul 2023 16:57:01 GMT",
        // 指定Object的存储类型。
        "x-oss-storage-class": "Standard",
        // 指定Object的访问权限。
        // "x-oss-object-acl": "private",
        // 设置Object的标签,可同时设置多个标签。
        "x-oss-tagging": "Tag1=1&Tag2=2",
        // 指定CopyObject操作时是否覆盖同名目标Object。此处设置为true,表示禁止覆盖同名Object。
        "x-oss-forbid-overwrite": "true",
        // "secure": "true"
    };
  3.  在组件中使用

    <template>
      <div class="upload">
        <el-upload ref="upload" style="display: inline-block;" action="" :limit="1" :http-request="httpRequest"
          :on-remove="handleRemove" :on-change="onChange" :before-upload="beforeAvatarUpload"
          :on-success="handleUploadSuccess" :file-list="fileList">
          <el-button type="info" size="mini">点击上传</el-button>
        </el-upload>
      </div>
    </template>
    
    <script>
    export default {
        data(){
        return {
            fileList: [],
            url: ''
        }
      },
         methods: {
            onChange(file, fileList) {
              console.log(file, 'file', fileList, 'Filest');
              this.fileList = fileList
            },
            handleUploadSuccess(response, file, fileList) {
              console.log(response, file, fileList, 'response, file, fileList')
            },
            handleRemove(e, fileList) {
              this.fileList = fileList;
            },
            beforeAvatarUpload(file) {
              // 文件大小校验
              const isLt2M = file.size / 1024 / 1024 < 10;
              if (!isLt2M) {
                this.$message.error('文件大小不能超过 10M !');
              }
              return isLt2M;
            },
            httpRequest(file) {//阿里云OSS上传
              //判断扩展名
              const tmpcnt = file.file.name.lastIndexOf(".") // 获取.的下标
              const uploadFileName = file.file.name.substring(0, tmpcnt) // 获取文件名
              console.log(uploadFileName, '文件名——uploadFileName');
              const exname = file.file.name.substring(tmpcnt + 1) // 获取后缀名
              console.log(exname, '后缀名');
              const names = ['jpg', 'jpeg', 'webp', 'png', 'bmp', 'exe', 'yml']
              if (names.indexOf(exname) < 0) {
                this.$message.error("不支持的格式!")
                return false
              }
              const fileName = uploadFileName
              console.log(fileName, '文件名');
              client.put(
                fileName,
                file.file,
                {
                  headers
                },
              ).then(res => {
                console.log(res, 'res---header ');
                // this.handleUploadSuccess()
                //   if (res.url) {
                //     this.url.push(res.url)
                //   } else {
                //     this.$message.error('文件上传失败')
                //   }
              }).catch(err => {
                console.log(err, 'err');
              })
        }
      }
    }
    </script>
    
    
  4.  上传成功,返回一个对象里边包含上传成功的url和上传的文件名vue 文件上传至服务器_oss文件服务器

  5.  上传完毕

注意点:

  1. 本地上传oss是http,服务器是https的就会出现问题,需要在oss.js文件里边配置,配置完之后在上传一下,就能看到返回的url是https
    secure:true // 返回的url为https
  2.  跨域之类的问题让运维配置下就可以了

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170642.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java 性能调优工具

    Java 性能调优工具Java 性能调优工具

    2022年4月23日
    37
  • npm 模块 移除_【已解决】npm卸载模块后该模块并没有从package.json中去掉[通俗易懂]

    折腾:期间,遇到一个奇怪的现象:用npmremovexxx或npmuninstallxxx后xxx并没有从package.json中去掉:➜HeadquarterReportgit:(permission-control)✗npmremoveelement-ui–async-validator@1.6.9node_modules/async-validator–babe…

    2022年4月10日
    68
  • 为低端浏览器定义原型方法matchAll[通俗易懂]

    为低端浏览器定义原型方法matchAll[通俗易懂]String.prototype.matchAll=function(reg){letmatchArr=[];letmatch;while((match=reg.exec(this))!==null){matchArr.push(match);}returnmatchArr;};

    2022年7月23日
    4
  • 渗透测试工具下载

    渗透测试工具下载好多工具资源

    2022年8月12日
    4
  • 云服务器和虚拟主机的区别

    云服务器和虚拟主机的区别云服务器和虚拟主机的区别:1、技术原理:云服务器是基于庞大的服务器资源池,是在一组集群主机上虚拟出多个类似独立主机的部分,集群中每个主机上都有云服务器的一个镜像;虚拟主机是服务器划分出的一部分,因此也叫做虚拟空间,在服务器当中划分出一定的磁盘空间放置web程序组件,提供数据的存放和传输功能。2、可用资源:云服务器是独享资源,具有独立的CPU、内存、硬盘和ip等;虚拟主机则是众多网站空间共享一台物理服务器的资源。3、主机费用:由于虚拟主机是多个空间分享一台服务器的带宽、IP等资源,费用低廉,价格比云服

    2022年6月25日
    30
  • 2020年软件测试前景_转行学软件测试的下场

    2020年软件测试前景_转行学软件测试的下场作为一名软件测试工程师,汇智妹可以负责任地告诉你:自信点,把“吗”去掉!为什么?本篇文章将从以下三个维度来为你解读:1.关于软件测试软件测试属新兴职业,且随着目前国内软件产业规模越来越大,软件行业也早已突破传统的作坊式生产,从单打独斗的开发模式升级为工业化、流水线式的生产模式,从而导致专业的软件测试人才需求缺口巨大。作为工业化产品质量的“把门”者,软件测试工程师已成为软件开发企业必不可少的技术人才。目前国内软件测试和开发人员比例大约在1:4~1:5,而国外测试和开发人员比例为1:1,由此

    2022年9月11日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号