ali oss上传文件_web端接入AliOss存储

本文详细介绍了如何在Web端使用阿里云OSS进行文件上传、断点续传、复制和下载操作。包括快速安装、设置Bucket、获取Token、上传文件、复制文件以及下载文件的方法,并提醒注意token时效性、下载限制和环境配置等问题。
摘要由CSDN通过智能技术生成

1、快速开始,安装

npm安装:

npm install ali-oss

直接引入:本地引入:

2、Bucket设置:(这步需要登录到oss管理系统配置)设置http请求方式。

3、获取token

因为我们项目是即时通讯 所以 通过socket cmd方式获取,具体与后台沟通

4、上传文件

上传blob数据

断点上传

/**

* web端阿里云上传

* @param {Object} files 上传资源

* @param {Object} result token

* @return {Object}*/retryAliUpSend: (files, result)=>{

let client= newOSS({

accessKeyId: result.AccessKeyId,

accessKeySecret: result.AccessKeySecret,

stsToken: result.SecurityToken,

endpoint: result.endpoint,

bucket: result.bucket,

secure:true});//上传命名=>自定义命名规则

const aliObjName = 'test001';//storeAs表示上传的object name , file表示上传的文件

client.multipartUpload(aliObjName, files).then(function(result) {//上传成功结果

}).catch(function(err) {

上传失败

});

},

5、复制文件

复制部分,web端无api文档,需通过查看源码找到复制方法

> aliObjName >> 新上传的key & filename

> sourceName >> oss存储内存已存在的key & filename

/**

* web端阿里云复制

* @param {Object} sourceName 需要复制的key

* @param {Object} aliObjName 上传命名(key)

* @param {Object} result token

* @return {Object}*/aliUpCopy: (sourceName,aliObjName,result)=>{

let client= newOSS({

accessKeyId: result.AccessKeyId,

accessKeySecret: result.AccessKeySecret,

stsToken: result.SecurityToken,

endpoint: result.endpoint,

bucket: result.bucket,

secure:true});//复制文件

client.copy(aliObjName, sourceName, {}).then(function(result) {

}).catch(function(err) {

});

},

6、下载文件

/**

* 下载

* @param {Object} URL objkey 即上传命名,阿里云oss上存储的文件名

* @param {Object} resize 需要限制下载的图片尺寸,可自定义

* @return {Object}*/downLoadAliUrl: (URL, resize)=>{//获取cookie存储的token

let aliOssMsg;if (utils.getCookie('setAliOssToken')) {

aliOssMsg= JSON.parse(utils.getCookie('setAliOssToken'));

}

let client= newOSS({

accessKeyId: aliOssMsg.AccessKeyId,

accessKeySecret: aliOssMsg.AccessKeySecret,

stsToken: aliOssMsg.SecurityToken,

endpoint: aliOssMsg.endpoint,

bucket: aliOssMsg.bucket,

secure:true});//下载文件

const result =client.signatureUrl(URL, {process: resize});returnresult;

}

ps:

a、token有时效性,考虑token是否实时获取

b、文件下载,下载视频或音频不能带resize

c、bucket,区分环境、域名。

*考虑不全,可查看官方api文档

好的,针对你的第一个问题,我可以告诉你如何使用 JavaScript 实现 OSS 批量下载文件的功能。 首先,你需要使用阿里云提供的 OSS SDK for JavaScript,通过 npm 安装: ``` npm install ali-oss --save ``` 然后,你可以使用以下代码实现批量下载文件: ```javascript const OSS = require('ali-oss'); const co = require('co'); const fs = require('fs'); // 创建 OSS 客户实例 const client = new OSS({ accessKeyId: '<AccessKeyId>', accessKeySecret: '<AccessKeySecret>', bucket: '<BucketName>', region: '<Region>', }); // 要下载的文件列表 const files = [ 'path/to/file1.txt', 'path/to/file2.txt', 'path/to/file3.txt', ]; // 下载文件 co(function* () { for (let file of files) { const result = yield client.get(file); fs.writeFileSync(`./${file}`, result.content); } }).catch(function (err) { console.log(err); }); ``` 这段代码首先创建了一个 OSS 客户实例,然后定义了要下载的文件列表,最后使用 `co` 库实现异步流程控制,循环遍历文件列表,逐个下载文件并保存到本地。 至于你提到的第二个问题,我可以告诉你如何在 NestJS 中使用阿里云 OSS 进行文件上传。 首先,你需要安装 `@nest-modules/multer` 和 `ali-oss` 两个库: ``` npm install @nest-modules/multer ali-oss --save ``` 然后,你可以在 NestJS 中定义一个上传服务: ```typescript import { Injectable } from '@nestjs/common'; import { MulterModule } from '@nest-modules/multer'; import * as OSS from 'ali-oss'; @Injectable() export class UploadService { private client: OSS; constructor() { this.client = new OSS({ accessKeyId: '<AccessKeyId>', accessKeySecret: '<AccessKeySecret>', bucket: '<BucketName>', region: '<Region>', }); } async upload(file: Express.Multer.File): Promise<string> { const result = await this.client.put(file.originalname, file.buffer); return result.url; } } ``` 这段代码定义了一个 `UploadService`,通过 `ali-oss` 库创建了一个 OSS 客户实例,在 `upload` 方法中实现了文件上传功能,返回上传后的文件 URL。 最后,你可以在 NestJS 控制器中使用这个上传服务: ```typescript import { Controller, Post, UseInterceptors, UploadedFile } from '@nestjs/common'; import { FileInterceptor } from '@nestjs/platform-express'; import { UploadService } from './upload.service'; @Controller('upload') export class UploadController { constructor(private readonly uploadService: UploadService) {} @Post() @UseInterceptors(FileInterceptor('file')) async upload(@UploadedFile() file: Express.Multer.File): Promise<string> { return this.uploadService.upload(file); } } ``` 这段代码定义了一个 `UploadController` 控制器,使用 `@UseInterceptors` 装饰器启用 `FileInterceptor` 中间件,将上传的文件传递给 `upload` 方法,调用上传服务上传文件并返回文件 URL。 希望这些代码能够帮助到你,如果你还有其他问题,可以随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值