首頁 >資料庫 >mysql教程 >如何在 NodeJS 中安全地轉義 MySQL 查詢的 JavaScript 字串?

如何在 NodeJS 中安全地轉義 MySQL 查詢的 JavaScript 字串?

Patricia Arquette
Patricia Arquette原創
2024-12-31 18:19:101003瀏覽

How to Safely Escape JavaScript Strings for MySQL Queries in NodeJS?

在NodeJS 中調整JavaScript 字串以進行MySQL 查詢

保護從JavaScript 傳遞到NodeJS 以及隨後傳遞到MySQL 的資料的完整性至關重要。雖然標準文字可以無縫集成,但電子郵件地址需要採用專門的方法來呈現 SQL 友善。

MySQL 的 mysql_real_escape_string() 函數旨在防止 SQL 注入漏洞,為準備 JavaScript 字串提供了一個有價值的框架。此功能可確保透過前置反斜線安全插入特殊字元( , x08, x09, x1a, n, r, ', ", , %)。

要在JavaScript 中複製此行為,您可以使用自訂function:

function mysql_real_escape_string(str) {
    return str.replace(/[\x08\x09\x1a\n\r"'\\%]/g, function(char) {
        switch (char) {
            case "":
                return "\0";
            case "\x08":
                return "\b";
            case "\x09":
                return "\t";
            case "\x1a":
                return "\z";
            case "\n":
                return "\n";
            case "\r":
                return "\r";
            case "\"":
            case "'":
            case "\":
            case "%":
                return "\"+char;
            default:
                return char;
        }
    });
}

套用此函數可以讓您在將JavaScript 字串中的特殊字元傳遞給NodeJS 進行SQL在插入之前有效地對其進行轉義,此外,對轉義製表符、退格鍵和“%”的擴展支援增強了 LIKE 查詢的穩健性,符合 OWASP 的安全準則。

以上是如何在 NodeJS 中安全地轉義 MySQL 查詢的 JavaScript 字串?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn