久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

node實(shí)現(xiàn)批量上傳本地圖片轉(zhuǎn)為圖片CDN的項(xiàng)目實(shí)踐

瀏覽:3日期:2022-06-12 15:05:48
目錄前言什么是圖片CDN為什么用圖片CDN實(shí)現(xiàn)過程結(jié)語前言

最近在做一個官網(wǎng),里面需要很多圖片,比較占用資源,打包體積有點(diǎn)大。所以想換成圖片CDN方式,之前寫過一個類似的,是需要后端同事提供接口,正好最近在看node,所以準(zhǔn)備用node實(shí)現(xiàn)一下。

什么是圖片CDN

與傳統(tǒng)的CDN不同,圖片CDN是CDN網(wǎng)絡(luò)的一種應(yīng)用,專門用于加速圖片的傳輸和加載,當(dāng)使用圖片CDN的時候,圖片被保存在CDN提供商的服務(wù)器上,并通過多個地理位置的邊緣節(jié)點(diǎn)提供服務(wù)。當(dāng)用戶請求訪問這些圖片時,CDN會自動將圖片傳送到距離用戶最近的邊緣節(jié)點(diǎn),從而實(shí)現(xiàn)快速加載和高可用性。

為什么用圖片CDN

1.可以提高網(wǎng)頁加載速度,因?yàn)閳D片被存儲在離用戶更近的服務(wù)器上,可以減少網(wǎng)絡(luò)延遲,加快傳輸速度,提高網(wǎng)頁加載速度。2.節(jié)省帶寬消耗,CDN可以分擔(dān)原始服務(wù)器的流量壓力,通過緩存圖片并在需要時提供服務(wù),從而減少原始服務(wù)器的帶寬消耗。3.減輕源服務(wù)器的負(fù)載,將圖片的從源服務(wù)器上轉(zhuǎn)移到CDN服務(wù)器上,減小了打包的體積,減輕了服務(wù)器的壓力。

實(shí)現(xiàn)過程

這次實(shí)現(xiàn)主要用的是express + cloudinary + node,主要借用了cloudinary,將圖片上傳到cloudinary,

將其中的cloud_name、api_key、api_secret換成自己就行,話不多說直接上代碼

const express = require('express');const multer = require('multer');const cloudinary = require('cloudinary').v2;const app = express();// 配置Multer中間件const storage = multer.diskStorage({? destination: (req, file, cb) => {? ? cb(null, 'uploads/'); // 指定上傳文件保存的目錄? },? filename: (req, file, cb) => {? ? cb(null, file.originalname); // 使用原始文件名保存上傳文件? }});const upload = multer({ storage });// 配置Cloudinarycloudinary.config({?? ? cloud_name: '*********',?? ? api_key: '*********',?? ? api_secret: '*********' ?? });// 處理文件上傳app.post('/upload', upload.array('images', 10), (req, res) => {? const files = req.files;? const uploadPromises = [];? // 遍歷所有上傳的文件? for (let i = 0; i < files.length; i++) {? ? const file = files[i];? ? const uploadPromise = new Promise((resolve, reject) => {? ? ? cloudinary.uploader.upload(file.path, (error, result) => {? ? ? ? if (error) {? ? ? ? ? reject(error);? ? ? ? } else {? ? ? ? ? resolve(result);? ? ? ? }? ? ? });? ? });? ? uploadPromises.push(uploadPromise);? }? // 等待所有文件上傳完成? Promise.all(uploadPromises)? ? .then(results => {? ? ? res.json(results);? ? })? ? .catch(error => {? ? ? res.status(500).json({ error: '上傳失敗' });? ? });});// 啟動應(yīng)用程序app.listen(3000, () => {? console.log('應(yīng)用程序已啟動');});

然后在本地啟動node服務(wù)就行,通過postman調(diào)用本地接口,實(shí)現(xiàn)批量上傳

其中的url就是我所需要的,可以直接放在img標(biāo)簽中,替換本地路徑的圖片換成cdn形式圖片

結(jié)語

寫這個服務(wù)的最大目的是為了偷懶,同時也方便打包減小打包體積,有條件的大佬可以在寫一個上傳頁面,不用在通過postman調(diào)用

到此這篇關(guān)于node實(shí)現(xiàn)批量上傳本地圖片轉(zhuǎn)為圖片CDN的項(xiàng)目實(shí)踐的文章就介紹到這了,更多相關(guān)node 批量圖片CDN內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 视频一区在线播放 | 黄色在线观看网址 | av一区二区在线观看 | 免费黄色看片 | 精品免费久久久久久久苍 | 噜噜噜天天躁狠狠躁夜夜精品 | 日韩视频免费在线播放 | 亚洲视频三区 | 日韩欧美中文在线 | 精品久久久久久久久久 | 国产精品久久久久久网站 | 99热这里有精品 | 欧美日韩精品综合 | 久久精品一区 | 欧美视频网站 | 日韩成人精品在线 | 亚洲精品3 | 日韩欧美a级v片免费播放 | 日韩欧美成人一区二区三区 | 91麻豆精品国产91久久久久 | 午夜在线电影 | 亚洲综合精品 | 久久香蕉国产视频 | 国产精品99久久免费观看 | 亚洲精品乱码久久久久久按摩观 | 亚洲精品久久一区二区三区 | 999国产| 一级二级黄色大片 | 亚洲午夜视频在线观看 | 91视频久久| 美女一级毛片 | 亚洲综合在线视频 | 国产亚洲精品久久久久久久久 | h片免费观看 | 伊人网站 | 四虎永久网址 | 国产欧美精品一区二区 | 精品国产91乱码一区二区三区 | 国产美女网站视频 | 羞羞视频网站在线看 | 日本高清精品 |