安全见闻5
今天学了Windows操作系统和驱动程序的相关知识
Windows注册表
注册表是windows系统中具有层次结构的核心数据库
储存的数据对windows 和Windows上运行的应用程序和服务至关重要。注册表时帮助windows控制硬件、软件、用户环境和windows界面的一套数据文件。
打开注册表编辑器
WIN+R 输入—>regedit
注册表结构
注册表中,所有的数据都是通过一种树状结构以键和子键的方式组织起来的,就像磁盘文件系统的目录结构一样。
每个键包含一组特定的信息,每个键的键名都是和它所包含的信息相关联的。注册表的根键共有5个,且全为大写。
可以通过编辑器完成开机自启动
注册表安全
影子用户
除了注册表里的文件,其他地方都不能查看到admin$的文件,无论管理员账号密码如何更改,都可以用改影子账户完成登陆和远程登陆。
映象劫持
注册表远程登陆
在线恶意文件检测平台
VirSCAN:https://www.virscan.org/language/zh-cn/
腾讯哈勃分析系统:https://habo.qq.com
魔盾安全分析:https://www.maldun.com/submit/submit_file/
微步在线云沙箱:https://s.threatbook.cn/
Jotti的恶意软件扫描系统:https://virusscan.jotti.org/
Falcon Sandbox:https://www.hybrid-analysis.com/
VirusTotal:https://www.virustotal.com/gui/home
奇安信文件深度分析平台:https://sandbox.ti.qianxin.com/
ScanVir:http://www.scanvir.com/
windows防火墙
Windows防火墙是操作系统中至关重要的安全组件,它可以有效地防止未经授权的访问和潜在的安全威胁。
windows计划任务
计划任务是系统的常见功能,利用任务计划功能,可以将任何脚本、程序或文档安排在某个最方便的时间运行。任务计划在每次系统启动的时候启动并在后台运行。
当我们需要在服务器上定时执行一些重复性的事件时使用的,可以通过计划任务程序来运行准备好的脚本、批处理文件夹、程序或命令,在某个特定的时间运行。
可以在任务计划程序窗口写入任务计划程序
打开任务计划程序窗口
方式一:控制面板–>windows工具–>任务计划程序
方式二:运行窗口或者撞断面板执行如下命令:Taskschd.msc
Windows10系统的任务计划程序窗口如下:
这个计划任务可以提权,到管理员权限,使用最高权限运行即可
如果是执行cmd脚本
说明:可以直接选择到具体路径就行,最好的保证能执行脚本的方法如下
路径:输入 cmd
添加参数:输入要执行的脚本路径,如c:\aa.bat
起始于:选择这个程序的执行的路径,一般会选择到该程序所在的目录,确保执行的时候,里面会调用到同目录文件,可以顺利调用
如果是执行powershell
说明:很多powershell脚本添加后是无法执行的,只能通过先打开powershell,然后把脚本当做一个参数输入,才能顺利打开
路径:输入powershell
添加参数:输入要执行的脚本路径,如:c:\aa.ps1
起始于:选择这个程序的执行的路径,一般会选择到该程序所在的目录,确保执行的时候,里面会调用到同目录文件,可以顺利调用
Windows事件日志
Windows事件日志是Windows操作系统中的一个重要组件,它记录了系统、应用程序和安全相关的活动。通过这些日志,管理员可以监控系统的健康状况、诊断问题以及检测潜在的安全威胁。
定义与功能
事件日志为操作系统及关联的应用程序提供一种标准化、集中式记录重要软件及硬件信息的方法。这些事件包括有关Windows组件和已安装应用程序的信息、警告和错误消息。事件日志可以为IT运维、开发运维和安全运维团队提供丰富的信息,帮助他们了解系统发生了什么,例如系统崩溃、恶意活动发生或基础设施故障等。
Windows内核驱动
驱动分类以及简单介绍
NT (Windows NT)
- 定义:Windows NT 是 Microsoft 开发的一系列操作系统的基础架构,首次发布于 1993 年。它是 Windows 操作系统的内核,支持多种硬件平台。
特点:
多用户和多任务:Windows NT 支持多用户和多任务处理,允许多个用户同时使用系统。
安全性:提供了强大的安全模型,包括用户权限和访问控制。
可移植性:设计上支持多种硬件架构,如 x86、x64、ARM 等。
模块化:操作系统的设计允许各种组件独立
版本:Windows NT 系列包括多个版本,如 Windows NT 3.1、Windows NT 4.0、Windows 2000、Windows XP、Windows Vista、Windows 7、Windows 8、Windows 10 和 Windows 11。
WDM (Windows Driver Model)
定义:WDM 是 Microsoft 提出的一个驱动程序模型,旨在为 Windows NT 系列操作系统提供统一的驱动程序接口。
特点:
统一接口:WDM 提供了一种标准化的接口,使得开发人员可以为多种类型的设备编写驱动程序,而无需为每种设备类型编写不同的代码。
支持多种设备类型:WDM 驱动程序可以支持各种设备,包括 USB、PCI、SCSI 和其他类型的硬件。
电源管理:WDM 还内置了电源管理功能,允许驱动程序有效管理设备的电源状态。
兼容性:WDM 驱动程序能够在多个 Windows 版本上运行,增加了设备的兼容性。
KWDF (Kernel-Mode Driver Framework)
定义:KWDF 是一种内核模式驱动程序框架,旨在帮助开发人员创建和管理 Windows 内核模式驱动程序。
特点:
提供了一个高层次的 API,简化了驱动程序的开发。
支持多种设备类型,包括 USB、PCI、SCSI 和其他硬件设备。
处理常见的驱动程序任务,如设备 I/O、设备创建和销毁、以及电源管理。
提供了事件和回调机制,以处理硬件事件。
使用场景:适用于需要直接与硬件交互并在内核模式下运行的驱动程序。
UWDF (User-Mode Driver Framework)
定义:UWDF 是一种用户模式驱动程序框架,允许驱动程序在用户模式下运行,从而提高系统的稳定性和安全性。
特点:
允许驱动程序在用户模式中执行,减少内核模式驱动程序的复杂性。
提供了与 KWDF 类似的 API,但专为用户模式设计。
在用户模式下运行的驱动程序可以更容易地进行调试和测试。
适合于较低复杂度的设备驱动程序,例如某些 USB 设备。
使用场景:适用于不需要直接与硬件交互或对性能要求不高的驱动程序。
总结:
NT是原生的核心架构,而WDM是基于NT衍生出的驱动开发框架,可以兼容多个NT版本
KWDF和UWDF是属于高度封装的一个框架,不直接接触到原生的API,为了方便驱动程序的开发而设计的
windows系统服务
什么是服务:可以在计算机启动时自动启动,可以暂停和重新启动的而且不显示任何用户界面。
1、可以用services.msc打开可视化界面进行查看和管理,也可以用CMD命令行进行操作。
服务安全
1、服务是一种允许用户执行各种任务和管理功能的机制,然而也带来安全威胁。
2、例如:特权升级、远程代码执行、信息泄漏、恶意软件传播。
3、处于安全考虑,我们要时刻关注运行的服务,是有陌生的服务运行,发现及时禁用掉。
4、导出运行的服务列表,及时作对比,看是否有增加。
5、攻击者很可能会将恶意代码或程序伪装成服务运行。
Windows进程线程
进程和线程的区别:
关系:进程包含线程。
根本区别:进程是系统分配资源的最小单位;线程是系统调度CPU执行的最小单位。
存储:多个进程的内存是隔离开的,一个进程中的多个线程可以共享内存。
开销:线程的创建、销毁的代价都比进程小。即 进程的状态转换 开销大于线程。
线程(假如有bug)可能会导致整个进程挂掉无法运行;而 进程间是独立运行的(也可能存在进程通信)
操纵者不同:进程的操纵者是操作系统(OS);线程的操纵者一般是程序员。
拥有资源不同:每个进程有自己的内存和资源,一个进程中的线程会共享这些内存和资源。
CPU利用率不同:进程的CPU利用率较低,因为上下文切换开销较大,而线程的CPU的利用率较高,上下文的切换速度快。
什么是进程?——Process
每个应用程序运行于现代操作系统之上时,操作系统会提供一种抽象,好像系统上只有这个程序在运 行,所有的硬件资源都被这个程序在使用。这种假象是通过抽象了一个进程的概念来完成的,进程可以说是计算机科学中最重要和最成功的概念之一。 进程是操作系统对一个正在运行的程序的一种抽象,换言之,可以把进程看做程序的一次运行过程; 同时,在操作系统内部,进程又是操作系统进行资源分配的基本单位。
进程是系统分配资源的最小单位。
操纵者:进程是由操作系统创建及管理的。(操作系统管理进程:(1)先创建一个PCB结构体——>用于 描述进程信息;(2)把多个进程PCB结构体,通过一定的数据结构组织起来)
系统对进程的调度:主要以 时间片轮转调度算法(一个CPU以时间片轮转调度的方式,依次执行多个进程)
进程的状态:创建状态、就绪状态、运行状态、阻塞状态、终止/销毁状态。
程序 和 进程
· 程序是在一个静态磁盘上的一个可执行文件。
· 进程是动态的,将可执行文件加载到系统中。加载就是将信息放在内存中,分配一些资源,并且执行程序中所有指令。
进程的存储—虚拟地址空间:
进程不直接使用物理内存,而是使用虚拟地址空间;
虚拟内存空间 里面里面是使用 分页式存储管理(页-Page-类似于书页目录)
PCB结构体:
(1)PID:进程ID,是进程的唯一身份标识(类似于数据库 主键,唯一性),但是它不是固定不变的,是每次启动进程时动态分配的。
(2)进程状态:5个。
(3)内存指针:进程内存地址
(4)资源清单:io设备,(硬件设备),硬盘文件
文件描述符表:定位硬盘中的文件,包括 默认创建三个文件描述符(输入输出):类似于java中的System.out(标准输出) 、 System.err(错误输出) 、System.in(标准输入)。
(5)调度信息:进程执行了多少代码,等待了多久.....
(5)上下文:保存本次的执行状态,以便下次执行。
三、什么是线程?——Thread
一个线程就是一个 " 执行流 ". 每个线程之间都可以按照顺讯执行自己的代码 . 多个线程之间 " 同时 " 执行着多份代码。线程是操作系统能够进行运算调度的最小单元。它被包含在进程中,是进程中实际运行的单位。一个进程中可以并发多个线程,每个线程执行不同的任务 。
线程是系统调度CPU执行的最小单位。
操纵者:线程的操纵者一般是编程人员。
Java线程的状态:创建状态、可运行状态、等待状态、超时等待状态、阻塞状态、销毁状态。
线程比进程更轻量级。所以虽然多进程也可以并发,也选择多线程。
线程的优势:(1)创建线程比创建进程更快;(2)销毁线程比销毁进程更快;(3)调度线程比调度进程更快
Windows系统编程
Windows系统编程是指在微软的Windows操作系统上开发应用程序的过程。Windows提供了大量的API(应用程序接口),这些API允许开发者访问系统的底层功能,如文件操作、网络通信、图形界面等。本篇文章将为初学者提供一个Windows编程的基础框架,包括所需工具、开发环境配置以及一些基本的编程概念。
理解Windows API
Windows API是一组函数的集合,它们为开发者提供了与操作系统交互的方式。通过这些API,你可以执行诸如创建窗口、读写文件等操作。
2. 使用MSDN文档
微软官方的MSDN文档是学习Windows API的最佳资源之一。这里不仅有详细的函数说明,还有使用示例和注意事项。
学习图形用户界面(GUI)编程
GUI编程是Windows应用开发的重要组成部分。了解如何使用MFC(Microsoft Foundation Classes)或WPF(Windows Presentation Foundation)等框架来创建美观且功能丰富的用户界面。