【Java代碼審計 | 第四篇】SQL 注入防范

文章目錄

    • Java SQL 注入防御方法
      • 類型轉換
      • 預編譯查詢(PreparedStatement)
      • 使用 ORM 框架(如 MyBatis、Hibernate)
      • 白名單限制
        • ORDER BY 語句
        • LIKE 語句
      • 限制數據庫權限
      • 過濾和轉義特殊字符
      • 監控與日志審計
      • 使用 Web 應用防火墻(WAF)

在這里插入圖片描述

Java SQL 注入防御方法

類型轉換

Java 是強類型語言,因此直接的數值型 SQL 注入較少,但仍需要注意參數類型的安全性。

int id = Integer.valueOf(req.getParameter("id"));

這樣可以確保 id 變量是整數,避免輸入 1 OR 1=1 之類的 SQL 語句攻擊。

預編譯查詢(PreparedStatement)

預編譯(Parameterized Queries)是防止 SQL 注入的最佳實踐,能夠確保用戶輸入的數據不會被解析為 SQL 代碼。

public User getUserById(String id) throws SQLException {Connection connection = JDBCTOOLS.getConnection(); // 獲取數據庫連接String sql = "SELECT id, username FROM user WHERE id = ?";PreparedStatement preparedStatement = connection.prepareStatement(sql);preparedStatement.setString(1, id);ResultSet resultSet = preparedStatement.executeQuery();if (resultSet.next()) {return new User(resultSet.getInt("id"), resultSet.getString("username"));}return null;
}

使用 ORM 框架(如 MyBatis、Hibernate)

ORM 框架能夠自動處理 SQL 預編譯,減少 SQL 注入的風險。

@Mapper
public interface CategoryMapper {@Select("SELECT * FROM category_ WHERE name = #{name}")Category getByName(String name);
}

白名單限制

某些情況下,用戶輸入可能用于 ORDER BYINLIKE 等 SQL 語句,預編譯無法有效防止注入。這時可使用白名單校驗。

ORDER BY 語句
private String checkSort(String sortBy) {List<String> columns = Arrays.asList("id", "username", "email");return columns.contains(sortBy) ? sortBy : "id";
}

這里通過 checkSort 方法,限定 ORDER BY 只能使用 白名單中的字段(id、username、email),如果 sortBy 不是合法字段,則默認按 id 排序。

String sql = "SELECT * FROM users ORDER BY " + checkSort(sortColumn);
LIKE 語句
String sql = "SELECT * FROM users WHERE username LIKE CONCAT('%', ?, '%')";
PreparedStatement preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1, userInput);

這里使用了 預編譯(PreparedStatement),將 userInput 作為參數傳遞,而不是直接拼接到 SQL 語句中。

限制數據庫權限

數據庫用戶權限應遵循最小權限原則,避免 root 賬戶執行 SQL 語句。

CREATE USER 'app_user'@'localhost' IDENTIFIED BY 'XXXX';

1、CREATE USER:在 MySQL 數據庫中創建一個新用戶。
2、‘app_user’@‘localhost’:用戶名是 app_user。
3、@‘localhost’ 指定該用戶只能從本機(localhost)連接到數據庫,不能從其他 IP 訪問。
4、IDENTIFIED BY ‘XXXX’:設置該用戶的密碼為 ‘XXXX’。

GRANT SELECT, INSERT, UPDATE ON mydb.* TO 'app_user'@'localhost';

1、GRANT:授予數據庫權限。
2、SELECT, INSERT, UPDATE:允許 app_user 在數據庫 mydb 中執行 查詢(SELECT)、插入(INSERT)、更新(UPDATE) 操作。
3、ON mydb.*:作用范圍是 mydb 數據庫中的所有表(* 代表所有表)。
4、TO ‘app_user’@‘localhost’:只將這些權限授予 本機的 app_user。

過濾和轉義特殊字符

可以對用戶輸入進行嚴格的字符過濾,但不建議完全依賴此方法。

public static String sanitize(String input) {return input.replaceAll("[';--]", "");
}

replaceAll() 會將單引號 (')、分號 (;)、雙減號 (–)替換為空字符串 “”,即刪除這些字符。

監控與日志審計

記錄 SQL 查詢日志,并監控異常 SQL 訪問。

LOGGER.warn("SQL Query Attempt: " + sqlQuery);

使用 Web 應用防火墻(WAF)

部署 WAF(如 ModSecurity)可以檢測和阻止 SQL 注入攻擊。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/71664.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/71664.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/71664.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

軟考中級-數據庫-3.3 數據結構-樹

定義:樹是n(n>=0)個結點的有限集合。當n=0時稱為空樹。在任一非空樹中,有且僅有一個稱為根的結點:其余結點可分為m(m>=0)個互不相交的有限集T1,T2,T3...,Tm…,其中每個集合又都是一棵樹,并且稱為根結點的子樹。 樹的相關概念 1、雙親、孩子和兄弟: 2、結點的度:一個結…

選擇排序算法的SIMD優化

一、優化原理 將查找數組最小值索引的SIMD優化的函數嵌入選擇排序主循環,優化最耗時的最小值查找環節,同時保留選擇排序的交換邏輯。 二、關鍵改造步驟 1)最小值查找模塊化 復用SIMD優化的 find_min_index_simd函數。 2)動態子數組處理 每次循環處理 arr[i..n-1] 子數…

考網絡安全工程師證要什么條件才能考?

在當今數字化時代&#xff0c;網絡安全問題日益凸顯&#xff0c;網絡安全工程師成為了一個備受矚目的職業。許多有志于投身這一行業的學子或職場人士&#xff0c;都希望通過考取網絡安全工程師證書來提升自己的專業素養和競爭力。那么&#xff0c;考網絡安全工程師證需要具備哪…

uniapp項目運行失敗Error: getaddrinfo *.bspapp.com 文件查找失敗uview-ui及推薦MarkDown軟件 Typora

一、uniapp項目運行失敗Error: getaddrinfo *.bspapp.com 文件查找失敗uview-ui 在運行一個uniapp項目時&#xff0c;出現報錯 文件查找失敗&#xff1a;uview-ui&#xff0c;Error: getaddrinfo ENOTFOUND 960c0a.bspapp.com。hostname異常&#xff0c;報錯的詳細信息如下&…

使用阿里云 API 進行聲音身份識別的方案

使用阿里云 API 進行聲音身份識別的方案 阿里云提供 智能語音交互&#xff08;智能語音識別 ASR&#xff09; 和 聲紋識別&#xff08;說話人識別&#xff09; 服務&#xff0c;你可以利用 阿里云智能語音 API 進行 說話人識別&#xff0c;實現客戶身份驗證。 方案概述 準備工…

【Pandas】pandas Series unstack

Pandas2.2 Series Computations descriptive stats 方法描述Series.argsort([axis, kind, order, stable])用于返回 Series 中元素排序后的索引位置的方法Series.argmin([axis, skipna])用于返回 Series 中最小值索引位置的方法Series.argmax([axis, skipna])用于返回 Series…

大模型發展歷程

大模型的發展歷程 大語言模型的發展歷程一、語言模型是個啥&#xff1f;二、語言模型的 “進化史”&#xff08;一&#xff09;統計語言模型&#xff08;SLM&#xff09;&#xff08;二&#xff09;神經語言模型&#xff08;NLM&#xff09;&#xff08;三&#xff09;預訓練語…

springboot項目使用中創InforSuiteAS替換tomcat

springboot項目使用中創InforSuiteAS替換tomcat 學習地址一、部署InforSuiteAS1、部署2、運行 二、springboot項目打包成war包 特殊處理1、pom文件處理1、排除內嵌的tomcat包2、新增tomcat、javax.servlet-api3、打包格式設置為war4、打包后的項目名稱5、啟動類修改1、原來的不…

Seata

Seata是一款開源的分布式事務解決方案&#xff0c;由阿里巴巴發起并維護&#xff0c;旨在幫助應用程序管理和協調分布式事務。以下是對Seata的詳細介紹&#xff1a; 一、概述 Seata致力于提供高性能和簡單易用的分布式事務服務&#xff0c;它為用戶提供了AT、TCC、SAGA和XA等…

Pytest自動化框架

Pytest簡單介紹 下載pytest pip install pytest 第一章&#xff1a;Pytest console命令 默認需要test開頭的py模塊,test_開頭的方法 1.pytest 執行pytest命令會自動匹配到test開頭或者結尾的文件 將其作為測試用例文件執行&#xff0c;在測試用例文件中自動匹配到test開…

【spring】注解版

1.管理bean 之前我們要想管理bean都是在xml文件中將想要添加的bean手動添加進ioc容器中&#xff0c;這樣太過麻煩了&#xff0c;在 Java 開發里&#xff0c;針對一些較為繁瑣的操作&#xff0c;通常會有相應的簡化方式&#xff0c;這個也不例外&#xff0c;就是spring提供的注…

RV1126+FFMPEG多路碼流監控項目

一.項目介紹&#xff1a; 本項目采用的是易百納RV1126開發板和CMOS攝像頭&#xff0c;使用的推流框架是FFMPEG開源項目。這個項目的工作流程如下(如上圖)&#xff1a;通過采集攝像頭的VI模塊&#xff0c;再通過硬件編碼VENC模塊進行H264/H265的編碼壓縮&#xff0c;并把壓縮后的…

13.IIC-EEPROM(AT24C02)

1.為什么需要EEPROM? 在單片機開發中&#xff0c;斷電數據保存是常見的需求。例如&#xff0c;智能家居設備的用戶設置、電子秤的校準參數等都需要在斷電后仍能保留。AT24C02作為一款IIC接口的EEPROM芯片&#xff0c;具備以下優勢&#xff1a; 非易失性存儲&#xff1a;斷電后…

ubuntu22.04安裝P104-100一些經驗(非教程)

一、版本&#xff1a; 系統&#xff1a;ubuntu-22.04.5-desktop-amd64.iso Nvidia 驅動&#xff1a;NVIDIA-Linux-x86_64-570.124.04.run。官網下載即可 二、經驗 1、通用教程? 直接關鍵詞搜“ubuntu p104”會有一些教程&#xff0c;比如禁用nouveau等 安裝參考&#xff1a…

TCP7680端口是什么服務

WAF上看到有好多tcp7680端口的訪問信息 于是上網搜索了一下&#xff0c;確認TCP7680端口是Windows系統更新“傳遞優化”功能的服務端口&#xff0c;個人理解應該是Windows利用這個TCP7680端口&#xff0c;直接從內網已經具備更新包的主機上共享下載該升級包&#xff0c;無需從微…

OSI七大模型 --- 發送郵件

我想通過電子郵件發送一張照片給我的朋友。從我開始寫郵件到發送成功&#xff0c;按照這個順序講一下我都經歷了OSI模型的哪一層&#xff0c;對應的層使用了什么樣的協議&#xff1f; 完整流程示例&#xff08;補充物理層細節&#xff09; 假設你通過Wi-Fi發送郵件&#xff1a…

LINUX網絡基礎 [一] - 初識網絡,理解網絡協議

目錄 前言 一. 計算機網絡背景 1.1 發展歷程 1.1.1 獨立模式 1.1.2 網絡互聯 1.1.3 局域網LAN 1.1.4 廣域網WAN 1.2 總結 二. "協議" 2.1 什么是協議 2.2 網絡協議的理解 2.3 網絡協議的分層結構 三. OSI七層模型&#xff08;理論標準&#xff09; …

【LLms】關鍵詞提取

1. 停用詞 在文本處理和信息檢索領域&#xff0c;停用詞&#xff08;Stop Words&#xff09;是指在文本中出現頻率較高&#xff0c;但通常不包含實際語義信息或對語義理解貢獻較小的詞匯。這些詞匯通常是一些常見的功能詞&#xff0c;如冠詞、介詞、連詞、代詞、感嘆詞、助動詞…

1998-2022年各地級市三次產業占比/地級市國內生產總值構成/地級市第一產業占比、第二產業占比、第三產業占比數據(全市)

1998-2022年各地級市三次產業占比/地級市國內生產總值構成/地級市第一產業占比、第二產業占比、第三產業占比數據&#xff08;全市&#xff09; 1、時間&#xff1a;1998-2022年 2、指標&#xff1a;第一產業占比、第二產業占比、第三產業占比 3、來源&#xff1a;城市統計年…

基于STM32的簡易出租車計費設計(Proteus仿真+程序+設計報告+原理圖PCB+講解視頻)

這里寫目錄標題 1.主要功能資料下載鏈接&#xff1a;2.仿真3. 程序4. 原理圖PCB5. 實物圖6. 設計報告7. 下載鏈接 基于STM32的簡易出租車計費設計(Proteus仿真程序設計報告原理圖PCB講解視頻&#xff09; 仿真圖proteus 8.9 程序編譯器&#xff1a;keil 5 編程語言&#xff1…