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

Node保存Canvas圖片并刪除過期圖片的操作步驟

 更新時間:2025年05月07日 09:43:07   作者:Jimmy  
本文,我們將探討,如何使用 Canvas 生成圖片,并通過 Node 將其保存在我們電腦的指定的位置,并在圖片文件過期之后,刪除該文件內容,以免占用我們的電腦存儲空間,下面小編給大家詳細演示一下操作步驟,需要的朋友可以參考下

引言

本文,我們將探討,如何使用 Canvas 生成圖片,并通過 Node 將其保存在我們電腦的指定的位置。并在圖片文件過期之后,刪除該文件內容,以免占用我們的電腦存儲空間。

我們將使用的演示環(huán)境如下:

  • NodeJs
  • Ejs 模版
  • macOS Sequoia 15.0

canvas 合成

我們通過 toDataURL 生成一張圖。

<canvas id="canvas" width="400" height="400"></canvas>
// 獲取花布
const canvas = document.getElementById("canvas");
// 獲取畫筆
const context = canvas.getContext("2d");

// 簡單繪制點什么
context.fillStyle = "#FFFF00";
context.fillRect(0, 0, 400, 400);

// other content ...
const dataUrl = canvas.toDataURL("image/png");

這里我們生成了 base64 的圖片數(shù)據(jù)。

按照網(wǎng)頁的下載方法,我們接下來的下載文件可以通過下面的方法來操作:

// 創(chuàng)建下載鏈接
const link = document.createElement("a");
link.href = dataUrl;
document.body.appendChild(link);
link.click();
document.body.removeChild(link);

網(wǎng)頁下載的位置因為安全策略,我們只能默認下載在瀏覽器指定的位置。我們可以通過手動更改 - 參考 How to specify shere files are downloaded

使用 node 下載圖片

這里我們使用 node 來將圖片文件下載在指定的位置。

下面是個簡單的開啟 node 服務的代碼:

// 使用 express Web 應用程序框架
const express = require("express");
const fs = require("fs");
const path = require("path");
const bodyParser = require("body-parser");
const app = express();
const port = 3000;

// 設置視圖引擎
app.set("view engine", "ejs");

// 設置視圖的文件位置
app.set("views", __dirname + "/views");

// 中間件解析 JSON 請求體
app.use(bodyParser.json({ limit: "50mb" }));

app.get("/", (req, res) => {
  // 渲染 index.ejs 模版
  res.render("index", {});
});

// 監(jiān)聽應用程序的開啟
app.listen(port, () => {
  console.log(`App listening at http://localhost:${port}`);
});

我們在 index.ejs 模版中發(fā)起請求:

// 發(fā)送 dataUrl 數(shù)據(jù)到服務器
fetch("/saveImage", {
  method: "POST",
  headers: {
    "Content-Type": "application/json",
  },
  body: JSON.stringify({ imageData: dataUrl })
})
.then((response => response.json()))
.then(data => {
  console.log(`Image saved in ${data.message}`);
})
.catch(error => {
  console.error("Error: ", error);
});

我們用 node 監(jiān)聽接口發(fā)送過來的數(shù)據(jù):

app.post("/saveImage", (req, res) => {
  // 圖片數(shù)據(jù)
  const { imageData } = req.body;
  
  // 移除數(shù)據(jù)的 URL 的前綴,根據(jù)生成的圖片的格式去操作,如果是 jpg 等更改相應內容
  const base64Data = imageData.replace(/^data:image\/png;base64,/, '');
  
  // 生成時間戳
  const timestamp = Date.now();
  const fileName = `${timestamp}.png`;
  
  // 指定保存的位置路勁
  const savePath = path.join(__dirname, "output", "${timestamp}", fileName);
});

  // 確保保存的路勁的目錄存在
  fs.mkdirSync(path.dirname(savePath), { recursive: true });
  
  // 寫入文件
  fs.writeFileSync(savePath, base64Data, "base64");
  
  // 返回數(shù)據(jù)給到請求接口
  res.json({ message: `Image saved to ${savePath}` });

然后我們在路由 / 頁面觸發(fā)下載之后,可以看到下載的文件內容

使用 node 刪除圖片

在圖片保存一定的時間之后,我們就需要刪除,以節(jié)省空間大小。我們實現(xiàn)如下:

我們在路由 /cleanCache 路由上操作,我們不需要在 ejs 上操作什么,一進入路由就執(zhí)行刪除操作,所以不需要對應的 ejs 文件。

對應的 node 代碼如下:

app.get("/cleanCache", (req, res) => {
  // 保存下載文件的文件夾
  const outputDir = path.join(__dirname, "output");
  
  // 讀取該目錄下的所有文件和子目錄
  fs.readdir(outputDir, (err, files) => {
    if (err) {
      return res.status(500).send("Unable to scan directory: ", err);
    }
    
    files.forEach(file => {
      const filePath = path.join(outputDir, file);
      
      // 獲取文件和目錄的狀態(tài)信息
      fs.stat(filePath, (err, stats) => {
        if (err) {
          console.error("Unable to get file stats: " + err);
          return;
        }
        
        // 獲取文件或目錄的修改時間
        
        const fileMtime = stats.mtime.getTime();
        const oneMinuteAgo = Date.now() - 60 * 1000; // 這里我們假設刪除 1 分鐘前的數(shù)據(jù)
        if (fileMtime < oneMinuteAge) {
          // 如果是目錄,則遞歸刪除目錄以及文件
          if (stats.isDirectory()) {
            fs.rm(filePath, { recursive: true, force: true }, err => {
              if (err) {
                console.error("Unable to delete directory: " + err);
              } else {
                console.log("Deleted directory: " + filePath);
              }
            });
          } else {
            // 如果是文件,則直接刪除
            fs.unlink(filePath, err => {
              if (err) {
                console.error("Unable to delete file: " + err);
              } else {
                console.log("Deleted file: " + filePath);
              }
            });
          }
        }
      });
    });
    
    res.send("Clear Done!");
  });
});

我們刪除 output 文件夾下面的過期文件。我們觸發(fā) /cleanCache 路由后,此時的 output 文件夾下會為空

到此這篇關于Node保存Canvas圖片并刪除過期圖片的操作步驟的文章就介紹到這了,更多相關Node保存Canvas圖片并刪除過期內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • nodejs中實現(xiàn)修改用戶路由功能

    nodejs中實現(xiàn)修改用戶路由功能

    這篇文章主要介紹了nodejs中實現(xiàn)修改用戶路由功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-05-05
  • Node.js使用Middleware中間件教程詳解

    Node.js使用Middleware中間件教程詳解

    中間件(Middleware),特指業(yè)務流程的中間處理環(huán)節(jié),Express中間件的調用流程-當一個請求處理時,可以連續(xù)調用多個中間件,從而對這次請求進行預處理
    2023-04-04
  • node.js調用腳本(python/shell)和系統(tǒng)命令

    node.js調用腳本(python/shell)和系統(tǒng)命令

    這篇文章介紹了node.js調用腳本(python/shell)和系統(tǒng)命令的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • node.js三個步驟實現(xiàn)一個服務器及Express包使用

    node.js三個步驟實現(xiàn)一個服務器及Express包使用

    這篇文章主要介紹了node.js三個步驟實現(xiàn)一個服務器及Express包使用,文章通過新建一個文件展開全文內容,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-05-05
  • nvm對Node.js進行版本控制的實現(xiàn)

    nvm對Node.js進行版本控制的實現(xiàn)

    本文主要介紹了用nvm來管理Node.js版本,通過nvm用戶可以輕松地在不同版本的Node.js之間切換,具有一定的參考價值,感興趣的可以了解一下
    2024-12-12
  • Node?文件查找優(yōu)先級及?Require?方法文件查找策略

    Node?文件查找優(yōu)先級及?Require?方法文件查找策略

    這篇文章主要介紹了Node文件查找優(yōu)先級及Require方法文件查找策略。文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • node.js中的console.time方法使用說明

    node.js中的console.time方法使用說明

    這篇文章主要介紹了node.js中的console.time方法使用說明,本文介紹了console.time的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • 利用adb shell和node.js實現(xiàn)抖音搶紅包功能(推薦)

    利用adb shell和node.js實現(xiàn)抖音搶紅包功能(推薦)

    這篇文章主要介紹了利用adb shell和node.js實現(xiàn)抖音搶紅包功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-02-02
  • NodeJs Express框架操作MongoDB數(shù)據(jù)庫執(zhí)行方法講解

    NodeJs Express框架操作MongoDB數(shù)據(jù)庫執(zhí)行方法講解

    MongoDB是一個介于關系數(shù)據(jù)庫和非關系數(shù)據(jù)庫之間的產品,是非關系數(shù)據(jù)庫當中功能最豐富,最像關系數(shù)據(jù)庫的。他支持的數(shù)據(jù)結構非常松散,是類似json的bjson格式,因此可以存儲比較復雜的數(shù)據(jù)類型
    2023-01-01
  • node.js實現(xiàn)的裝飾者模式示例

    node.js實現(xiàn)的裝飾者模式示例

    這篇文章主要介紹了node.js實現(xiàn)的裝飾者模式,簡單說明了裝飾者模式的原理、功能并結合實例形式給出了node.js裝飾者模式的實現(xiàn)方法,需要的朋友可以參考下
    2017-09-09

最新評論