DAY9:Oracle数据库安全管理深度解析

news2025/4/25 22:47:28

引言

在当今数据泄露事件频发的时代,数据库安全管理已成为DBA和开发者的必修课。本文将深入探讨Oracle数据库安全管理的四大核心领域:用户权限管理、数据库审计、透明数据加密(TDE)和虚拟私有数据库(VPD),并附赠完整实验教程。无论您是刚入门的新手还是经验丰富的DBA,都能从中获得新的启发。


一、用户权限管理:构建安全的第一道防线

1.1 权限体系的三层架构

  • 系统权限:数据库级别的操作权限(CREATE SESSION、CREATE TABLE等)

  • 对象权限:具体数据库对象的操作权限(SELECT ON employees)

  • 角色机制:权限集合的抽象容器(CONNECT、RESOURCE等)

1.2 实战权限配置

-- 创建角色并授权
CREATE ROLE data_analyst;
GRANT CREATE SESSION, SELECT ANY TABLE TO data_analyst;

-- 对象权限精确控制
GRANT SELECT, UPDATE (salary) ON hr.employees TO data_analyst;

-- 角色继承体系
CREATE ROLE senior_analyst;
GRANT data_analyst TO senior_analyst;
GRANT EXECUTE ON hr.salary_procedure TO senior_analyst;

1.3 权限查询技巧

-- 查看用户系统权限
SELECT * FROM dba_sys_privs WHERE grantee = 'DATA_ANALYST';

-- 查看表权限详情
SELECT * FROM dba_tab_privs WHERE owner = 'HR';

二、数据库审计:全方位监控的艺术

2.1 标准审计配置

-- 启用数据库审计
AUDIT CREATE TABLE, DROP TABLE BY ACCESS;

-- 查看审计记录
SELECT username, action_name, timestamp 
FROM dba_audit_trail 
WHERE action_name IN ('CREATE TABLE','DROP TABLE');

2.2 细粒度审计(FGA)进阶

BEGIN
 DBMS_FGA.ADD_POLICY(
   object_schema => 'HR',
   object_name => 'EMPLOYEES',
   policy_name => 'SALARY_ACCESS_AUDIT',
   audit_condition => 'salary > 20000',
   audit_column => 'SALARY',
   handler_schema => NULL,
   handler_module => NULL,
   enable => TRUE);
END;
/

2.3 审计优化策略

  • 设置审计日志自动归档

  • 使用UNIFIED AUDITING新特性

  • 配置审计日志存储限额


三、透明数据加密(TDE):数据安全的终极铠甲

3.1 TDE实战四部曲

  1. 创建密钥库

ADMINISTER KEY MANAGEMENT CREATE KEYSTORE '/wallet_dir' IDENTIFIED BY "KeystorePass123";
  1. 打开密钥库

ADMINISTER KEY MANAGEMENT SET KEYSTORE OPEN IDENTIFIED BY "KeystorePass123";
  1. **创建主密钥

ADMINISTER KEY MANAGEMENT SET KEY IDENTIFIED BY "KeystorePass123" WITH BACKUP;
  1. **加密敏感列

ALTER TABLE hr.employees MODIFY (salary ENCRYPT USING 'AES256');

3.2 TDE管理技巧

  • 定期轮换加密密钥

  • 多密钥分级管理策略

  • 加密表空间与列加密的抉择


四、虚拟私有数据库(VPD):数据访问的智能过滤器

4.1 VPD策略三步走

  1. 创建策略函数

CREATE OR REPLACE FUNCTION hr_dept_policy(
 p_schema IN VARCHAR2,
 p_object IN VARCHAR2)
RETURN VARCHAR2
AS
BEGIN
 RETURN 'department_id = SYS_CONTEXT(''USERENV'', ''SESSION_DEPT_ID'')';
END;
  1. 附加策略到表

BEGIN
 DBMS_RLS.ADD_POLICY(
  object_schema => 'HR',
  object_name => 'EMPLOYEES',
  policy_name => 'DEPT_POLICY',
  function_schema => 'HR',
  policy_function => 'hr_dept_policy',
  statement_types => 'SELECT,UPDATE');
END;
  1. **上下文管理

CREATE CONTEXT dept_ctx USING set_dept_context_pkg;

五、综合实验:构建全方位安全防护

实验1:敏感操作审计

-- 创建细粒度审计策略
BEGIN
 DBMS_FGA.ADD_POLICY(
   object_schema => 'HR',
   object_name => 'PAYMENTS',
   policy_name => 'HIGH_VALUE_AUDIT',
   audit_condition => 'amount > 100000',
   audit_column => 'AMOUNT');
END;

实验2:列级数据加密

-- 创建加密列
CREATE TABLE financial_records (
 record_id NUMBER ENCRYPT,
 client_name VARCHAR2(100),
 transaction_amount NUMBER(15,2) ENCRYPT USING 'AES192'
);

-- 验证加密状态
SELECT column_name, encryption_alg 
FROM dba_encrypted_columns 
WHERE table_name = 'FINANCIAL_RECORDS';

六、安全防护升级指南

  1. 权限管理黄金法则

  • 遵循最小权限原则

  • 定期进行权限复核(推荐每月一次)

  • 禁用默认账户(SYS、SYSTEM除外)

  1. 审计优化建议

  • 设置审计日志自动归档策略

  • 对特权用户进行重点监控

  • 结合操作系统审计日志分析

  1. 加密最佳实践

  • 密钥备份策略(至少保留3个历史版本)

  • 使用HSM进行密钥管理

  • 测试环境禁用加密

  1. VPD高级技巧

  • 动态策略条件生成

  • 结合应用程序上下文

  • 策略函数性能优化


结语

数据库安全是一场永无止境的攻防战。通过本文的系统学习,您已经掌握了Oracle安全管理的四大核心武器。但切记:技术手段只是基础,真正的安全源于持续的安全意识、完善的制度和定期的演练。现在,是时候将这些知识应用到您的生产环境了!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2342757.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RK3588平台用v4l工具调试USB摄像头实践(亮度,饱和度,对比度,色相等)

目录 前言:v4l-utils简介 一:查找当前的摄像头设备 二:查看当前摄像头支持的v4l2-ctl调试参数 三根据提示设置对应参数,在提示范围内设置 四:常用调试命令 五:应用内执行命令方法 前言:v4l-utils简介 v4l-utils工具是由Linu…

在Linux中,使用read函数去读取写入文件空洞部分时,读取出来的内容是什么?为什么这样操作,以及应用场景?

使用 read 函数读取文件空洞(hole)部分时,读取到的内容会被系统填充为 \0(即零字节)。文件空洞是稀疏文件中未实际分配磁盘空间的区域,但逻辑上表现为连续的零字节。 1.在指定空洞部分后,写入数…

Qt6笔记-对Qt6中对CMakeLists.txt的解析

首先,新建Qt Console Application项目。 下面对CMakeLists.txt进行次理解。新建好后,Qt Creator会生成CMakeLists.txt,具体内容如下: cmake_minimum_required(VERSION 3.16)project(EasyCppMain LANGUAGES CXX)set(CMAKE_AUTOUIC…

CIFAR10图像分类学习笔记(三)---数据加载load_cifar10

新创建一个load_cifar10源文件 需要导入的包 import glob from torchvision import transforms from torch.utils.data import DataLoader ,Dataset import os #读取工具 from PIL import Image import numpy as np 01同样定义10个类别的标签名数组 label_name ["airpl…

计算机视觉cv入门之答题卡自动批阅

前边我们已经讲解了使用cv2进行图像预处理与边缘检测等方面的知识,这里我们以答题卡自动批阅这一案例来实操一下。 大致思路 答题卡自动批阅的大致流程可以分为这五步:图像预处理-寻找考试信息区域与涂卡区域-考生信息区域OCR识别-涂卡区域填涂答案判断…

Java学习手册:JSON 数据格式基础知识

1. JSON 简介 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于阅读和编写,也易于机器解析和生成。它最初来源于 JavaScript,但如今已被许多语言所采用,包括 Java、Python、C 等。JSON 以…

《重塑AI应用架构》系列: Serverless与MCP融合创新,构建AI应用全新智能中枢

在人工智能飞速发展的今天,数据孤岛和工具碎片化问题一直是阻碍AI应用高效发展的两大难题。由于缺乏统一的标准,AI应用难以无缝地获取和充分利用数据价值。 为了解决这些问题,2024年AI领域提出了MCP(Model Context Protocol模型上…

深度图可视化

import cv2# 1.读取一张深度图 depth_img cv2.imread("Dataset_depth/images/train/1112_0-rgb.png", cv2.IMREAD_UNCHANGED) print(depth_img.shape) cv2.imshow("depth", depth_img) # (960, 1280) print(depth_img)# 读取一张rgb的图片做对比 input_p…

微软Edge浏览器字体设置

前言 时间:2025年4月 自2025年4月起,微软Edge浏览器的默认字体被微软从微软雅黑替换成了Noto Sans,如下图。Noto Sans字体与微软雅黑风格差不多,但在4K以下分辨率的显示器上较微软雅黑更模糊,因此低分辨率的显示器建议…

Vue生命周期详细解析

前言 Vue.js作为当前最流行的前端框架之一,其生命周期钩子函数是每个Vue开发者必须掌握的核心概念。本文将全面解析Vue的生命周期,帮助开发者更好地理解Vue实例的创建、更新和销毁过程。 一、Vue生命周期概述 Vue实例从创建到销毁的整个过程被称为Vue…

基于c#,wpf,ef框架,sql server数据库,音乐播放器

详细视频: 【基于c#,wpf,ef框架,sql server数据库,音乐播放器。-哔哩哔哩】 https://b23.tv/ZqmOKJ5

前端项目搭建集锦:vite、vue、react、antd、vant、ts、sass、eslint、prettier、浏览器扩展,开箱即用,附带项目搭建教程

前端项目搭建集锦:vite、vue、react、antd、vant、ts、sass、eslint、prettier、浏览器扩展,开箱即用,附带项目搭建教程 前言:一、Vue项目下载快速通道二、React项目下载快速通道三、BrowserPlugins项目下载快速通道四、项目搭建教…

什么是Maven

Maven的概念 Maven是一个一键式的自动化的构建工具。Maven 是 Apache 软件基金会组织维护的一款自动化构建工具,专注服务于Java 平台的项目构建和依赖管理。Maven 这个单词的本意是:专家,内行。Maven 是目前最流行的自动化构建工具&#xff0…

neo4j中节点内的名称显示不全解决办法(如何让label在节点上自动换行)

因为节点过多而且想让节点中所有文字都显示出来而放大节点尺寸 从neo4j中导出png,再转成PDF来查看时,要看清节点里面的文字就得放大5倍才行 在网上看了很多让里面文字换行的办法都不行 然后找到一个比较靠谱的办法是在要显示的标签内加换行符 但是我的节点上显示的是…

【GIT】github中的仓库如何删除?

你可以按照以下步骤删除 GitHub 上的仓库(repository): 🚨 注意事项: ❗️删除仓库是不可恢复的操作,所有代码、issue、pull request、release 等内容都会被永久删除。 🧭 删除 GitHub 仓库步骤…

3台CentOS虚拟机部署 StarRocks 1 FE+ 3 BE集群

背景:公司最近业务数据量上去了,需要做一个漏斗分析功能,实时性要求较高,mysql已经已经不在适用,做了个大数据技术栈选型调研后,决定使用StarRocks StarRocks官网:StarRocks | A High-Performa…

【HCIA】简易的两个VLAN分别使用DHCP分配IP

前言 之前我们通过 静态ip地址实现了Vlan间通信 ,现在我们添加一个常用的DHCP功能。 文章目录 前言1. 配置交换机2. 接口模式3. 全局模式后记修改记录 1. 配置交换机 首先,使用DHCP,需要先启动DHCP服务: [Huawei]dhcp enable I…

艾蒙顿桌面app下载-Emotn UI下载安装-emotn ui官方tv版安卓固件

在智能电视桌面应用的领域里,Emotn UI 凭借其简洁无广告、可自定义等特点,赢得了不少用户的关注。然而,小编深入了解后发现了一款更好用的电视桌面——乐看家桌面在诸多方面更具优势,能为你带来更优质的大屏体验。 乐看家桌面内置…

3、ArkTS语言介绍

目录 基础知识函数函数声明可选参数Rest参数返回类型箭头函数(又名Lambda函数)闭包 类字段字段初始化getter和setter继承父类访问方法重写方法重载签名可见性修饰符(Public、Private、protected) 基础知识 ArkTS是一种为构建高性…

修改了Element UI中组件的样式,打包后样式丢失

修改了Element UI中组件的样式,在本地运行没有问题,但是打包到线上发现样式丢失(样式全部不生效、或者有一部分生效,一部分不生效),问题在于css的加载顺序导致代码编译后样式被覆盖了, 解决办法…