创建腾讯云存储桶---上传图片--使用cos-sdk完成上传

创建腾讯云存储桶---上传图片

注册腾讯云账号https://cloud.tencent.com/login

登录成功,选择右边的控制台

点击云产品,选择对象存储

创建存储桶

填写名称,选择公有读,私有写一直下一步,到创建

选择安全管理,添加规则

把存储桶名称和所属地域复制保存下来,后面使用,

获取应用标识,进入这个链接https://console.cloud.tencent.com/cam/capi将SecretId和SecretKey拷贝下来,备用。

这里需要使用保存好的----存储桶的名称-地域名称-应用标识-应用密钥

安装腾讯云js-sdk--------使用cos-sdk完成上传

$ npm i cos-js-sdk-v5

$ yarn add cos-js-sdk-v5

页面一

html 复制代码
  <el-row>
    <el-col :span="12">
       <el-form-item label="上传图片">
         <!-- 放置上传图片 -->
         <image-upload v-model="userInfo.staffPhoto"></image-upload>
       </el-form-item>
     </el-col>
   </el-row>

页面二

使用el-upload自定义上传

这里需要知道Cos的初始化和上传的方法

html 复制代码
<template>
  <el-upload
    class="avatar-uploader"
    action=""
    :show-file-list="false"
    :http-request="uploadImage"
  >
    <img v-if="value" :src="value" class="avatar">
    <i v-else class="el-icon-plus avatar-uploader-icon" />
  </el-upload>
</template>

实现上传方法

javascript 复制代码
import COS from "cos-js-sdk-v5";
export default {
 props: {
    value: {
      type: String,
      default: "",
    },
  },
  methods:{
    // 选择图片上传
    uploadImage(params) {
      console.log(params.file)
      const cos = new COS({
        SecretId: "填写自己的",
        SecretKey: "填写自己的",
      }) // 完成cos对象的初始化
      cos.putObject({
        Bucket: "填写自己的", // 存储桶名称
        Region: "填写自己的", // 地域名称
        Key: params.file.name, // 文件名称
        StorageClass: 'STANDARD', // 固定值
        Body: params.file // 文件对象
      }, (err, data) => {
        if (data.statusCode === 200 && data.Location) {
          // 拿到了腾讯云返回的地址
          // 通过input自定义事件将地址传出去
          this.$emit('input', 'http://' + data.Location) // 将地址返回了
        } else {
          this.$message.error(err.Message) // 上传失败提示消息
        }
      })
    }
   } 
相关推荐
浮游本尊19 小时前
React 18.x 学习计划 - 第四天:React Hooks深入
前端·学习·react.js
future_studio20 小时前
聊聊 Unity(小白专享、C# 小程序 之 日历、小闹钟)
前端·html
Yeats_Liao20 小时前
Go Web 编程快速入门 · 04 - 请求对象 Request:头、体与查询参数
前端·golang·iphone
祈祷苍天赐我java之术20 小时前
Redis 数据类型与使用场景
java·开发语言·前端·redis·分布式·spring·bootstrap
草莓熊Lotso21 小时前
C++ 方向 Web 自动化测试入门指南:从概念到 Selenium 实战
前端·c++·python·selenium
Olrookie1 天前
若依前后端分离版学习笔记(二十)——实现滑块验证码(vue3)
java·前端·笔记·后端·学习·vue·ruoyi
533_1 天前
[vue] dayjs 显示实时时间
前端·javascript·vue.js
故事与他6451 天前
XSS_and_Mysql_file靶场攻略
前端·学习方法·xss
莫的感情1 天前
下载按钮点击一次却下载两个文件问题
前端
一个很帅的帅哥1 天前
JavaScript事件循环
开发语言·前端·javascript