首页 > 其他分享 >oss前端签名直传

oss前端签名直传

时间:2022-12-03 00:13:21浏览次数:37  
标签:console log dataObj oss 签名 file data 直传

最近项目中要用到直传, 所以整理一下自己使用oss前端直传中遇到的问题

前端直传(前端保存oss账号,不安全)

let OSS = require('ali-oss')
export let client = new OSS({
  region: 'oss-cn-hangzhou',  // 填你的oss所在区域,例如oss-cn-shenzhen
  accessKeyId: 'LTAI5t6HAduxYGxxxxxxxxxxxxxx', // 填你的oss的accessKeyId
  accessKeySecret: 'wZaToZpLSqRxxxxxxxxxxxxxxxxxxk', // 填你的oss的accessSecret
  bucket: 'gyh2jlj' // 你创建的路径名称
})
其实也就是对oss对象的方法的调用:
          client.multipartUpload(filename, blobInfo.blob()).then(function (result) {
            if (result.res.requestUrls) {
              // 这里获取上传至阿里云的数据地址
              console.log('返回结果', result.res.requestUrls)
              success(result.res.requestUrls[0].split('?')[0])
            }
          }).catch(function (err) {
            console.log(err)
          })

服务端签名直传

这个是从后台获取到签名,然后前端进行直传
image

<template> 
  <div>
    <el-upload
      action="你创建的Bucket中的Bucket域名,xu"
      :data="dataObj"
      list-type="picture"
      :multiple="false" :show-file-list="showFileList"
      :file-list="fileList"
      :before-upload="beforeUpload"
      :on-remove="handleRemove"
      :on-success="handleUploadSuccess"
      :on-preview="handlePreview">
      <el-button size="small" type="primary">点击上传</el-button>
      <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过10MB</div>
    </el-upload>
    <el-dialog :visible.sync="dialogVisible">
      <img width="100%" :src="fileList[0].url" alt="">
    </el-dialog>
  </div>
</template>
<script>

  export default {
    name: 'singleUpload',
    props: {
      value: String
    },
    computed: {
      imageUrl() {
        return this.value;
      },
      imageName() {
        if (this.value != null && this.value !== '') {
          return this.value.substr(this.value.lastIndexOf("/") + 1);
        } else {
          return null;
        }
      },
      fileList() {
        return [{
          name: this.imageName,
          url: this.imageUrl
        }]
      },
      showFileList: {
        get: function () {
          return this.value !== null && this.value !== ''&& this.value!==undefined;
        },
        set: function (newValue) {
        }
      }
    },
    data() {
      return {
        // 封装服务端返回的数据
        dataObj: {
          policy: '',
          signature: '',
          key: '',
          ossaccessKeyId: '',
          dir: '',
          host: '',
        },
        dialogVisible: false
      };
    },
    methods: {
      emitInput(val) {
        this.$emit('input', val)
      },
      handleRemove(file, fileList) {
        this.emitInput('');
      },
      handlePreview(file) {
        this.dialogVisible = true;
      },
      beforeUpload(file) {
        console.log(file.size);
        let _self = this;
        return new Promise((resolve, reject) => {
          // 这里使用了封装的请求方式,可以直接换成axios即可
          http({
            url: http.adornUrl("/oss/policy"),
            method: "get",
            params: http.adornParams({})
          }).then(response => {
            console.log("响应的数据",response);
            _self.dataObj.policy = response.data.policy;
            _self.dataObj.signature = response.data.signature;
            _self.dataObj.ossaccessKeyId = response.data.accessid;
            // 存放进oss的命名格式为uuid+原本文件名
            _self.dataObj.key = response.data.dir + '/' + getUUID()+'_${filename}';
            _self.dataObj.dir = response.data.dir;
            _self.dataObj.host = response.data.host;
            resolve(true)
          }).catch(err => {
            reject(false)
          })
        })
      },
      handleUploadSuccess(res, file) {
        console.log("上传成功...")
        this.showFileList = true;
        this.fileList.pop();
        this.fileList.push({name: file.name, url: this.dataObj.host + '/' + this.dataObj.key.replace("${filename}",file.name) });
        this.emitInput(this.fileList[0].url);
      }
    }
  }
</script>
<style>

</style>

需要阿里云服务器配置跨域,开启读写权限

最后是STSToken临时授权上传

参考https://segmentfault.com/a/1190000020963346
以及官网https://help.aliyun.com/document_detail/64041.html

1.       // 获取STS token
      this.credentials = await _api_stsTokenUpdata()
	  
2.	      // 创建对象
      this.ossClient = new OSS({
        region: 'oss-cn-beijing',
        accessKeyId: this.credentials.data.accessKeyId,
        accessKeySecret: this.credentials.data.accessKeySecret,
        stsToken: this.credentials.data.securityToken,
        bucket: this.credentials.data.bucketName,
        secure: true
      })
3. this.ossClient.multipartUpload(fileName, file, {
        parallel:this.parallel,//同时上传几片
        partSize:this.partSize,//每片大小
        progress: (p, cpt, res) => {
              // 为中断点赋值。
              this.abortCheckpoint = cpt;
              console.log('abortCheckpoint',this.abortCheckpoint);
              // 获取上传进度。
              console.log(p * 100);
              this.per = Math.floor(p*100)
            },//进度条
      }).then(result => {
        // 生成文件下载地址
        const url = `http://${bucket}.${region}.aliyuncs.com/${fileName}`;
        console.log(`分片上传Multipart upload ${file.name} succeeded, url === `, url)
      }).catch(err => {
        console.log(`分片上传Multipart upload ${file.name} failed === `, err);
      });
    },

标签:console,log,dataObj,oss,签名,file,data,直传
From: https://www.cnblogs.com/gyh907368/p/16842624.html

相关文章

  • 使用自签名证书在Docker中部署Asp.Net Core(Abp)项目
    一编写Dockerfile文件FROMmcr.microsoft.com/dotnet/aspnet:6.0COPY//appWORKDIR/appEXPOSE80ENTRYPOINT["dotnet","Acme.BookStore.Web.dll"]#设置时区......
  • 小程序支付前端报requestPayment:fail:支付验证签名失败
    重要的事情说三遍:二次签名时key使用驼峰重要的事情说三遍:二次签名时key使用驼峰重要的事情说三遍:二次签名时key使用驼峰真的头大,直接把微信APP支付的代码给干过来了,结果签名......
  • torch.nn.CrossEntropyLoss
    文章目录​​交叉熵损失函数`torch.nn.CrossEntropyLoss`​​​​F.cross_entropy​​​​F.nll_loss​​交叉熵损失函数​​torch.nn.CrossEntropyLoss​​weight(Tensor......
  • 源码注释中的"方法签名"是什么意思?
    我们经常可以在源码注释中看到methodsignature,也就是方法签名,那它指的是方法中的哪部分呢?好比@Async中的第二段注释中《Java语言程序设计》一书中对方法的描述中有......
  • HALO博客配置华为云OSS上传附件
    大家好,我是满心前言之前使用的服务器本地存储,用了半年左右发现,存储量较大,而且访问速度也很慢,就考虑使用OBS存储方式,由于我使用的是华为云服务器,所以这里也选用华为的OBS,其实......
  • Vulnhub之bossplayersCTF 1靶机详细测试过程
    bossplayersCTF:1作者:jason_huawen靶机基本信息名称:bossplayersCTF:1地址:https://www.vulnhub.com/entry/bossplayersctf-1,375/提示:AimedatBeginnerSecurity......
  • JAVA整合阿里云OSS/VUE上传阿里云OSS
    前言今天码帮帮系统已经整合到上传项目案例的功能了,这里有一些图片资源需要上传,之前做项目对接过七牛云,也有使用过阿里云的视频点播服务,不过这次对接阿里云的OSS确实有点......
  • 2、通知签名(把两个文件合并成一个文件)
    如果通知有两份文件的话,那么领导若不在办公室,在家办公,那么他签名的时候只会签第二页的文件,他反馈回来的是一张图片,那么如何把一个【pdf文件】和【图片】合并成一张图片用......
  • VR手术培训是炒作?融资6600万美金的Osso VR并不同意
     “元宇宙的开拓者”是我们针对元宇宙的发展而设立的专栏,主要面向那些深挖元宇宙产业或者在元宇宙进行“淘金”的从业者,分享这些企业或者创业者们的故事,以独特的视角窥见那......
  • 验证签名
    packagecom.cloud7.utils;importcom.fasterxml.jackson.databind.ObjectMapper;importlombok.SneakyThrows;importorg.apache.commons.codec.binary.Base64;importorg......