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静态内部类(static class)[通俗易懂]

    Java静态内部类(static class)[通俗易懂]在一个类中创建另外一个类,叫做成员内部类。这个成员内部类可以静态的(利用static关键字修饰),也可以是非静态的。一、静态内部类的使用目的。在定义内部类的时候,在其前面加上一个权限修饰符static。这个内部类就变为了静态内部类。如在进行代码程序测试的时候,如果在每一个Java源文件中都设置一个主方法(主方法是某个应用程序的入口,必须具有),那么会出现很多额外的代码。而且最主要的是这段主…

    2022年10月11日
    0
  • zabbix安装——安装php

    zabbix安装——安装php

    2021年9月8日
    46
  • 什么是Unicode字符_Unicode格式字符是什么

    什么是Unicode字符_Unicode格式字符是什么写这篇博客的原因,从做软件开始,什么ASCII码,Unicode,UTF-8,UTF-16,UTF-32……这些鬼东西总是经常碰到,只知道这些鬼是编码格式,其他的就啥都不清楚了,既然总是遇

    2022年8月1日
    3
  • C语言格式输出

    C语言格式输出格式说明由“%”和格式字符组成,如:%d%f等。它的作用是将输出的数据转换成指定的格式输出。格式说明总是由“%”字符开始的。格式字符有:d、o、x、u、c、s、f、e、g等。1、%d整形输出,%ld长整形输出。2、%o以八进制数形式输出整数。3、%x以十六进制形式输出整数,或输出字符串的地址。4、%u以十进制数输出unsigned型整数(无符号数)。注意:%d与%u有无符号数值范围。5、%c用来输出一个字符。6、%s用来输出一个字符串。7、%f用来输出实数,以小数形式输出,默认情况下保留小数

    2022年7月24日
    7
  • 学Python后到底能干什么?

    学Python后到底能干什么?Python是一种什么语言?Python是一种计算机程序设计语言。你可能已经听说过很多种流行的编程语言,比如非常难学的C语言,非常流行的Java语言,适合初学者的Basic语言,适合网页编程的Jav

    2022年7月3日
    23
  • shell if语句和test命令

    shell if语句和test命令在shell中if条件判断语句和我们的C、C++、Java等语言是不同的,shell的if语句条件必须用[]括起来,另外[]里外都需要用空格与周围隔开(例如[a==b]),否则报错;另外与if配对的有elseif和else,如果我们要写这两个必须后面跟有东西,否则也会报错,在编程中不跟是可以的:if(a==b)printf("a=b");else{//什么都没有}但是s…

    2022年7月27日
    3

发表回复

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

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