分布式电商项目二十六:使用阿里云存储的服务端签名后直传(前端联调)

使用阿里云存储的服务端签名后直传(前端联调)

在前端显示上传的界面,可以根据人人fast-vue的结构,在src\components目录下添加upload文件夹,直接添加vue组件即可,总计三个组件,需要自己修改跳转的上传路径并确认上传的服务器访问地址:
multiUpload.vue:

<template>
  <div>
    <el-upload
      action="http://lastingwar.oss-cn-hangzhou.aliyuncs.com"
      :data="dataObj"
      list-type="picture-card"
      :file-list="fileList"
      :before-upload="beforeUpload"
      :on-remove="handleRemove"
      :on-success="handleUploadSuccess"
      :on-preview="handlePreview"
      :limit="maxCount"
      :on-exceed="handleExceed"
    >
      <i class="el-icon-plus"></i>
    </el-upload>
    <el-dialog :visible.sync="dialogVisible">
      <img width="100%" :src="dialogImageUrl" alt />
    </el-dialog>
  </div>
</template>
<script>
import {
    policy } from "./policy";
import {
    getUUID } from '@/utils'
export default {
   
  name: "multiUpload",
  props: {
   
    //图片属性数组
    value: Array,
    //最大上传图片数量
    maxCount: {
   
      type: Number,
      default: 30
    }
  },
  data() {
   
    return {
   
      dataObj: {
   
        policy: "",
        signature: "",
        key: "",
        ossaccessKeyId: "",
        dir: "",
        host: "",
        uuid: ""
      },
      dialogVisible: false,
      dialogImageUrl: null
    };
  },
  computed: {
   
    fileList() {
   
      let fileList = [];
      for (let i = 0; i < this.value.length; i++) {
   
        fileList.push({
    url: this.value[i] });
      }

      return fileList;
    }
  },
  mounted() {
   },
  methods: {
   
    emitInput(fileList) {
   
      let value = [];
      for (let i = 0; i < fileList.length; i++) {
   
        value.push(fileList[i].url);
      }
      this.$emit("input", value);
    },
    handleRemove(file, fileList) {
   
      this.emitInput(fileList);
    },
    handlePreview(file) {
   
      this.dialogVisible = true;
      this.dialogImageUrl = file.url;
    },
    beforeUpload(file) {
   
      let _self = this;
      return new Promise((resolve
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值