前端上传到oss

安装oss

npm install ali-oss --save

import OSS from "ali-oss"; //引入oss


export async function ossClient(file, name) {

  if (!name) {
   // 自定义文件上传的名字
    name = "tools/material/avatar_lib/";
  }
  let fileName = `${name}img${Date.parse(new Date())}oss.png`;

   //这里的file文件是本地选择好图片的临时url地址,需要转换为blob格式
  const imgBlob = await fetch(file).then((r) => r.blob());
  const imgFile = new File([imgBlob], fileName, { type: imgBlob.type });
  
  var client = new OSS({

    //地区信息根据自己的地方信息选择不同的字段
    region: "oss-cn-hangzhou.aliyuncs.com",

    //下面的字段都是后端返回的缺一不可
    accessKeyId: data.accessid,
    accessKeySecret: data.access_secret,
    stsToken: data.security_token,
    bucket: data.bucket_name,
    endpoint: data.endpoint,
  }); //后端提供数据

  // 自定义请求头
  const headers = {
    
    "Content-Disposition": "inline",
  };

  // let fileName = `img${Date.parse(new Date())}${imgFile.name}`;
  try {
    const result = await client.put(fileName, imgFile, { headers });
    return result;
  } catch (error) {
    console.error("上传失败", error);
    // 处理上传失败的情况
  }
}

页面使用

<script setup>

//此路径为封装上传oss的js文件路径
import { ossClient } from "@/utils/alioss.js";


const onChooseImg = () => {
  uni.chooseImage({
    count: 1, //默认9
    sizeType: ["compressed"], //可以指定是原图还是压缩图,默认二者都有
    sourceType: ["album"], //从相册选择
    success: async (res) => {
     // console.log(res);
      let result = await ossClient(res.tempFilePaths[0]);
     // console.log(result, "返回值");
    },
  });
};

</script>

<template>

   <view @tap="onChooseImg">选择图片</view>

</template>

要将文件上传到阿里云 OSS,需要进行以下几个步骤: 1. 安装阿里云 OSS 的 SDK,可以使用官方提供的 `ali-oss` 包。 2. 在前端代码中,通过 `input` 标签获取用户选择的文件,然后将文件传递给后端。 3. 在后端代码中,使用阿里云 OSS 的 SDK,将文件上传OSS。 下面是一个简单的 Vue.js 前端代码,用于获取用户选择的文件,并向后端发送文件数据: ```html <template> <div> <input type="file" ref="fileInput" @change="uploadFile"> </div> </template> <script> import axios from 'axios' export default { methods: { async uploadFile() { const file = this.$refs.fileInput.files[0] const formData = new FormData() formData.append('file', file) const res = await axios.post('/api/upload', formData) console.log(res) } } } </script> ``` 在上面的代码中,我们使用了 `axios` 库来发送 POST 请求,并将文件数据封装在 `FormData` 对象中。接下来,在后端代码中,我们需要使用 `ali-oss` 库将文件上传OSS: ```javascript const OSS = require('ali-oss') const koaBody = require('koa-body') const client = new OSS({ region: 'your-region', accessKeyId: 'your-accessKeyId', accessKeySecret: 'your-accessKeySecret', bucket: 'your-bucket' }) const uploadFile = async (ctx) => { const file = ctx.request.files.file const result = await client.put(file.name, file.path) ctx.body = { url: result.url } } app.use(koaBody({ multipart: true, formidable: { maxFileSize: 200 * 1024 * 1024 // 设置上传文件大小的上限 } })) app.use(router.post('/api/upload', uploadFile)) ``` 上面的代码中,我们首先使用 `ali-oss` 的 `client` 对象来进行初始化,其中需要填写 OSS 的一些基本信息,比如区域、AccessKeyId、AccessKeySecret 和 Bucket 名称等。 然后,在 `uploadFile` 函数中,我们通过 `ctx.request.files` 对象获取到前端上传的文件数据,然后使用 `client.put` 方法将文件上传OSS 中,并返回文件的访问 URL。 最后,我们在 `koa-body` 中启用 `multipart` 模式,以支持文件上传,并设置 `formidable` 的 `maxFileSize` 属性来限制上传文件的大小上限。然后,我们在路由中注册上传文件的接口,以便前端可以将文件数据传递给后端。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值