Vue3快速實(shí)現(xiàn)文件上傳OSS的方法詳解
前言
上傳文件可以說是經(jīng)典的需求了,在后臺管理項(xiàng)目中隨處可見。一般是由前端進(jìn)行文件上傳,然后再由后端去處理??梢赃x擇把文件放到服務(wù)器上,但是隨著后續(xù)文件增多,可能會(huì)對服務(wù)器的開銷比較大,所以一般都采用OSS(Object Storage Service)對象存儲(chǔ)服務(wù),將我們的文件上傳到第三方服務(wù)上,而我們只需要通過url去訪問文件就可以了。那么今天就讓我們來簡單實(shí)現(xiàn)一下文件上傳的功能吧。
前端采用的是Element plus的upload組件,后端是NodeJS,采用阿里云的OSS服務(wù)進(jìn)行存儲(chǔ)。
本文旨在實(shí)現(xiàn)上傳功能,不考慮額外的功能(如文件尺寸限制)。
前端
前端引用一下組件,需要注意的是Element plus的upload組件提供了action配置項(xiàng),填寫請求URL就可以上傳文件。

但為了后期維護(hù),我們一般都不采用action配置項(xiàng),而是將其賦值為#,通過http-request封裝我們自己的請求方法。
通過組件庫文檔可知,我們的doUpload方法會(huì)獲得一個(gè)options參數(shù),我們來看看這個(gè)參數(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);
}
這里有個(gè)要點(diǎn),因?yàn)槭荈ormData表單對象,所以我們需要在請求頭中設(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進(jìn)行編寫。
首先簡單實(shí)現(xiàn)以下接口(注:由于我采用的是TypeScript,所以可以使用ESModule即import和export進(jìn)行模塊引入導(dǎo)出)。
import express from 'express';
const app = express();
app.post('/uploadImg',(req, res) => {});
app.listen(1300, () => {})
由于我們使用post請求,所以需要通過body-parser中間件對請求體的數(shù)據(jù)進(jìn)行解析,使解析后的數(shù)據(jù)可用于后續(xù)的請求處理。
通過pnpm add body-parser 進(jìn)行安裝。
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文件夾下,如果沒有會(huì)創(chuàng)建。
// 接口中進(jìn)行文件解析
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來獲取處理好的文件,那么我們來看看打印一下這個(gè)req.file里有什么吧。

可以看到里面包含了關(guān)于文件的一些信息,比如名稱、類型、地址等,其中名稱和地址會(huì)是我們所需要的參數(shù)。
OSS服務(wù)
在阿里云的OSS文檔里有提供文件上傳的示例代碼。

進(jìn)入后我們選擇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名稱。
// 如果本地文件的完整路徑中未指定本地路徑,則默認(rèn)從示例程序所屬項(xiàng)目對應(yīng)本地路徑中上傳文件。
const result = await client.put(filename, fileData);
return result;
} catch (e) {
console.log(e);
}
}
以上就是完整的上傳方法,只需要填寫配置就行,其中accessKeyId和accessKeySecret可以通過個(gè)人面板的AccessKey管理創(chuàng)建獲取。

隨后我們就可以在接口中進(jìn)行調(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)在為止,我們代碼基本實(shí)現(xiàn)了,接下來看看成果吧。

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

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

總結(jié)
以上就是通過Element Plus的Upload組件、NodeJS和阿里OSS服務(wù)實(shí)現(xiàn)的文件上傳簡單實(shí)現(xiàn)啦。我是花椒,如果你覺得我的文章還不錯(cuò)就給我點(diǎn)個(gè)贊吧~ 如果有什么錯(cuò)誤也歡迎評論指正哦~
到此這篇關(guān)于Vue3快速實(shí)現(xiàn)文件上傳OSS的方法詳解的文章就介紹到這了,更多相關(guān)Vue3實(shí)現(xiàn)文件上傳OSS內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue使用less報(bào)錯(cuò):Inline JavaScript is not ena
這篇文章主要介紹了vue使用less報(bào)錯(cuò):Inline JavaScript is not enabled問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
vue項(xiàng)目記錄鎖定和解鎖功能實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了vue項(xiàng)目記錄鎖定和解鎖功能實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別
這篇文章主要介紹了vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue elementui table編輯表單時(shí)彈框增加編輯明細(xì)數(shù)據(jù)的實(shí)現(xiàn)
在Vue項(xiàng)目中,通過使用Element UI框架實(shí)現(xiàn)表單及其明細(xì)數(shù)據(jù)的新增和編輯操作,主要通過彈窗形式進(jìn)行明細(xì)數(shù)據(jù)的增加和編輯,有效提升用戶交互體驗(yàn),本文詳細(xì)介紹了相關(guān)實(shí)現(xiàn)方法和代碼,適合需要在Vue項(xiàng)目中處理復(fù)雜表單交互的開發(fā)者參考2024-10-10
vue中的路由跳轉(zhuǎn)tabBar圖片和文字的高亮效果
這篇文章主要介紹了vue中的路由跳轉(zhuǎn)tabBar圖片和文字的高亮效果,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10

