Vue3快速實現(xiàn)文件上傳OSS的方法詳解
前言
上傳文件可以說是經(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-Type
為application/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); } }
以上就是完整的上傳方法,只需要填寫配置就行,其中accessKeyId
和accessKeySecret
可以通過個人面板的AccessKey管理
創(chuàng)建獲取。
隨后我們就可以在接口中進行調(diào)用,傳入所需的filename
和fileData
。
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)文章
vue使用less報錯:Inline JavaScript is not ena
這篇文章主要介紹了vue使用less報錯:Inline JavaScript is not enabled問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別
這篇文章主要介紹了vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11vue elementui table編輯表單時彈框增加編輯明細數(shù)據(jù)的實現(xiàn)
在Vue項目中,通過使用Element UI框架實現(xiàn)表單及其明細數(shù)據(jù)的新增和編輯操作,主要通過彈窗形式進行明細數(shù)據(jù)的增加和編輯,有效提升用戶交互體驗,本文詳細介紹了相關(guān)實現(xiàn)方法和代碼,適合需要在Vue項目中處理復(fù)雜表單交互的開發(fā)者參考2024-10-10vue中的路由跳轉(zhuǎn)tabBar圖片和文字的高亮效果
這篇文章主要介紹了vue中的路由跳轉(zhuǎn)tabBar圖片和文字的高亮效果,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10