欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3快速實現(xiàn)文件上傳OSS的方法詳解

 更新時間:2024年01月28日 10:02:58   作者:吃她喵的花椒  
這篇文章給大家介紹了Vue3快速實現(xiàn)文件上傳OSS的方法,上傳文件可以說是經(jīng)典的需求了,在后臺管理項目中隨處可見,一般是由前端進行文件上傳,然后再由后端去處理,本文旨在實現(xiàn)上傳功能,不考慮額外的功能(如文件尺寸限制),感興趣的朋友可以參考下

前言

上傳文件可以說是經(jīng)典的需求了,在后臺管理項目中隨處可見。一般是由前端進行文件上傳,然后再由后端去處理??梢赃x擇把文件放到服務(wù)器上,但是隨著后續(xù)文件增多,可能會對服務(wù)器的開銷比較大,所以一般都采用OSS(Object Storage Service)對象存儲服務(wù),將我們的文件上傳到第三方服務(wù)上,而我們只需要通過url去訪問文件就可以了。那么今天就讓我們來簡單實現(xiàn)一下文件上傳的功能吧。

前端采用的是Element plus的upload組件,后端是NodeJS,采用阿里云的OSS服務(wù)進行存儲。

本文旨在實現(xiàn)上傳功能,不考慮額外的功能(如文件尺寸限制)。

前端

前端引用一下組件,需要注意的是Element plus的upload組件提供了action配置項,填寫請求URL就可以上傳文件。

但為了后期維護,我們一般都不采用action配置項,而是將其賦值為#,通過http-request封裝我們自己的請求方法。

通過組件庫文檔可知,我們的doUpload方法會獲得一個options參數(shù),我們來看看這個參數(shù)里有什么。

可以看到通過options可以獲取到組件的一些屬性和方法,其中的file就是我們所需要上傳的文件對象。將其解構(gòu)出來通過FormData創(chuàng)建表單對象將文件通過我們封裝的upload方法傳輸?shù)胶蠖恕?/p>

const doUpload = async (options: any) => {
  const { file } = options;
  const formData = new FormData();
  formData.append('file', file);
  await upload(fileData);
}

這里有個要點,因為是FormData表單對象,所以我們需要在請求頭中設(shè)置Content-Typeapplication/form-data,這樣后端才可以識別我們上傳的文件,upload方法如下。

const headers = {
  'Content-type': 'application/form-data'
};
export function upload(params: any) {
  return instance.post('/uploadImg', params, { headers });
}

后端

后端我們采用express進行編寫。

首先簡單實現(xiàn)以下接口(注:由于我采用的是TypeScript,所以可以使用ESModule即import和export進行模塊引入導(dǎo)出)。

import express from 'express';
const app = express();

app.post('/uploadImg',(req, res) => {});

app.listen(1300, () => {})

由于我們使用post請求,所以需要通過body-parser中間件對請求體的數(shù)據(jù)進行解析,使解析后的數(shù)據(jù)可用于后續(xù)的請求處理。

通過pnpm add body-parser 進行安裝。

import bodyParser from 'body-parser';
app.use(bodyParser.json({ limit: '10mb' }));
app.use(bodyParser.urlencoded({ limit: '10mb', extended: true }));

以及還需要cors中間件解決跨域問題。

pnpm add cors。

import cors from 'cors';
app.use(cors());

最后,我們還需要multer中間件處理我們上傳的文件,具體使用如下。

pnpm add multer

import multer from 'multer';
const upload = multer({ dest: 'uploads/' }); // 指明文件的地址,即我們后端服務(wù)的uploads文件夾下,如果沒有會創(chuàng)建。

// 接口中進行文件解析
app.post('/uploadImg', upload.single('file'), async (req: any, res: Response) => {})

這里的upload.single表明只處理上傳數(shù)據(jù)中的file字段對應(yīng)的數(shù)據(jù),也就是我們之前formData.append('file',file)里的file文件,如果你設(shè)置的是其他字段如fileData,那么中間件就要寫為upload.single('fileData')。

我們可以通過req.file來獲取處理好的文件,那么我們來看看打印一下這個req.file里有什么吧。

可以看到里面包含了關(guān)于文件的一些信息,比如名稱、類型、地址等,其中名稱和地址會是我們所需要的參數(shù)。

OSS服務(wù)

在阿里云的OSS文檔里有提供文件上傳的示例代碼。

進入后我們選擇NodeJS的SDK參考,通過下圖路徑可以看到本文所需的示例代碼。

可以看到要使用OSS服務(wù)需要下載ali-oss第三方庫。

pnpm add ali-oss。

import * as OSS from 'ali-oss';

const client = new OSS.default({
  // yourRegion填寫B(tài)ucket所在地域。以華東1(杭州)為例,Regin填寫為oss-cn-hangzhou。
  region: 'oss-cn-hangzhou',
  accessKeyId: '你的阿里云key',
  accessKeySecret: '你的阿里云keyScerect',
  // 填寫B(tài)ucket名稱,例如examplebucket。
  bucket: '你阿里云OSS的桶名'
});

export async function put(filename: string, fileData: File) {
  try {
    // 填寫OSS文件完整路徑和本地文件的完整路徑。OSS文件完整路徑中不能包含Bucket名稱。
    // 如果本地文件的完整路徑中未指定本地路徑,則默認從示例程序所屬項目對應(yīng)本地路徑中上傳文件。
    const result = await client.put(filename, fileData);
    return result;
  } catch (e) {
    console.log(e);
  }
}

以上就是完整的上傳方法,只需要填寫配置就行,其中accessKeyIdaccessKeySecret可以通過個人面板的AccessKey管理創(chuàng)建獲取。

隨后我們就可以在接口中進行調(diào)用,傳入所需的filenamefileData。

router.post('/uploadImg', upload.single('file'), async (req: any, res: Response) => {
  const file = req.file;
  const result = await put(file.originalname, file.path);
  res.send({ code: 200, data: { fileName: result?.name, url: result?.url } });
});

到現(xiàn)在為止,我們代碼基本實現(xiàn)了,接下來看看成果吧。

可以在阿里云的OSS中看到我們上傳的文件。

而在后端也可獲取到接口返回的文件名和外鏈地址。

總結(jié)

以上就是通過Element Plus的Upload組件、NodeJS和阿里OSS服務(wù)實現(xiàn)的文件上傳簡單實現(xiàn)啦。我是花椒,如果你覺得我的文章還不錯就給我點個贊吧~ 如果有什么錯誤也歡迎評論指正哦~

到此這篇關(guān)于Vue3快速實現(xiàn)文件上傳OSS的方法詳解的文章就介紹到這了,更多相關(guān)Vue3實現(xiàn)文件上傳OSS內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue2里面ref的具體使用方法

    vue2里面ref的具體使用方法

    本篇文章主要介紹了vue2里面ref的具體使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • Vue開發(fā)環(huán)境的搭建全過程

    Vue開發(fā)環(huán)境的搭建全過程

    文章介紹了在網(wǎng)頁中使用Vue.js的四種方式:基本方式、腳手架方式(Vue2.0)、使用WebStorm集成環(huán)境創(chuàng)建vue-cli項目(Vue3.0)以及Vue項目的目錄結(jié)構(gòu),每種方式都有詳細的步驟和示例,幫助讀者快速上手Vue.js開發(fā)
    2024-11-11
  • vue2.0多條件搜索組件使用詳解

    vue2.0多條件搜索組件使用詳解

    這篇文章主要為大家詳細介紹了vue2.0多條件搜索組件的實現(xiàn)方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • vue使用less報錯:Inline JavaScript is not enabled問題

    vue使用less報錯:Inline JavaScript is not ena

    這篇文章主要介紹了vue使用less報錯:Inline JavaScript is not enabled問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • vue項目記錄鎖定和解鎖功能實現(xiàn)

    vue項目記錄鎖定和解鎖功能實現(xiàn)

    這篇文章主要為大家詳細介紹了vue項目記錄鎖定和解鎖功能實現(xiàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別

    vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別

    這篇文章主要介紹了vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue代碼整潔之去重方法整理

    Vue代碼整潔之去重方法整理

    在本篇文章里小編給大家整理的是關(guān)于Vue代碼整潔之去重的相關(guān)知識點內(nèi)容,需要的朋友們學(xué)習(xí)下。
    2019-08-08
  • vue elementui table編輯表單時彈框增加編輯明細數(shù)據(jù)的實現(xiàn)

    vue elementui table編輯表單時彈框增加編輯明細數(shù)據(jù)的實現(xiàn)

    在Vue項目中,通過使用Element UI框架實現(xiàn)表單及其明細數(shù)據(jù)的新增和編輯操作,主要通過彈窗形式進行明細數(shù)據(jù)的增加和編輯,有效提升用戶交互體驗,本文詳細介紹了相關(guān)實現(xiàn)方法和代碼,適合需要在Vue項目中處理復(fù)雜表單交互的開發(fā)者參考
    2024-10-10
  • vue3.x中apollo的使用案例代碼

    vue3.x中apollo的使用案例代碼

    這篇文章主要介紹了vue3.x中apollo的使用,通過前端自身直接獲取到apollo的配置目前看到官方支持的客戶端是沒有vue的,本文給大家介紹了前端獲取到apollo數(shù)據(jù)的過程,需要的朋友可以參考下
    2023-02-02
  • vue中的路由跳轉(zhuǎn)tabBar圖片和文字的高亮效果

    vue中的路由跳轉(zhuǎn)tabBar圖片和文字的高亮效果

    這篇文章主要介紹了vue中的路由跳轉(zhuǎn)tabBar圖片和文字的高亮效果,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評論