SQL安全:常见手段

前面我们从基础的单表查询一直聊到优化,讲了SQL的很多内容。这一节我们来说说怎么让我们的数据库变得更安全。

为了实现常见的业务场景,数据库会提供很多的功能。有一些功能如果被攻击者利用,就很容易获取到不应该让其获取到的信息。比如union拼接、比如1=1拼接。

常见的手段,可以在应用程序角度数据库引擎角度进行分类。

应用程序角度

在应用程序角度,最直接的就是对用户输入进行格式校验,不符合要求的报错处理。

其次就是参数化查询。这个是很常见的预防SQL拼接注入的方法。即将用户输入的内容作为参数传递给预编译的SQL。由于预编译时数据库会缓存SQL的执行计划,所以一定程度上也能提高程序的性能。

有一些恶意注入会利用报错信息,所以在程序中要对报错信息 也进行一定的屏蔽。如果为了方便排查,可以单独建表对错误堆栈进行记录。

数据库引擎角度

针对用户进行权限最小化处理,是数据库角度最常见的操作。

启用数据库的审计功能,记录数据库的操作日志。牺牲一些性能来换取更高的安全性。

配置数据库的安全参数,比如禁用动态SQL、使用强密码策略等。数据库为了保证安全,提供了很多的配置选项。

小结

这一节我们讲述了为了保证SQL安全而使用的常见手段,在具体业务过程中一般要结合起来使用,以达到维护数据库安全的目的。

相关推荐
{Hello World}2 分钟前
MySQL学习----------相关库表操作
数据库·学习·mysql
青衫码上行13 分钟前
高频 SQL 50题(基础版)| 连接
数据库·sql·mysql
一个响当当的名号16 分钟前
lectrue17 时间戳排序并发控制
数据库
xyzhan18 分钟前
SQL Server - 列出数据库中所有固定长度字段
数据库·sql·oracle·sql server
skywalk816326 分钟前
新华字典:pwxcoo/chinese-xinhua 中华新华字典数据库。包括歇后语,成语,词语,汉字。
数据库·字典
念越32 分钟前
MySQL 聚合函数与分组查询全解析
数据库·mysql
知识分享小能手1 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 数据库的备份与恢复 — 语法知识点及使用方法详解(19)
数据库·学习·sqlserver
倔强的石头1061 小时前
一卡通核心交易平台的国产数据库实践解析:架构、迁移与高可用落地
数据库·架构·kingbase
GDAL1 小时前
SQLite 核心特性与应用实战教程:轻量却不简单的嵌入式数据库
数据库·sqlite
源码获取_wx:Fegn08951 小时前
计算机毕业设计|基于springboot + vue家政服务平台系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计