前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >系统安全策略查看配置命令一览表

系统安全策略查看配置命令一览表

作者头像
全栈工程师修炼指南
发布2022-09-28 19:32:28
1.9K0
发布2022-09-28 19:32:28
举报

[TOC]

0x01 secedit 命令 - 命令行中操作组策略计算机安全策略

描述:组策略是建立Windows安全环境的重要手段尤其是在Windows域环境下, 我们可以采用secedit 命令行操作组策略进行命令文本的方式下进行设置, 或者系统管理员肯定使用gpedit.msc在窗口界面下访问组策略。

WeiyiGeek.gpedit
WeiyiGeek.gpedit

WeiyiGeek.gpedit

组策略相关文件路径

组策略的计算机安全策略模板存放路径

  • %SYSTEMROOT%\security\templates

系统默认的安全数据库路径

  • %windir%\security\database\secedit.sdb

如果没有/log指定配置操作信息将被记录到scesrv.log

%windir%\security\logs目录之中

代码语言:javascript
复制
PS C:\Users\WeiyiGeek> ls C:\Windows\Security\Database\
目录: C:\Windows\Security\Database
Mode                 LastWriteTime         Length Name
----                 -------------         ------ ----
-a----        2020/12/10      0:06           8192 edb.chk
-a----        2020/12/10      0:06        1048576 edb.log
-a----        2020/12/10      0:06        1048576 edb00001.log
-a----         2020/11/4     23:44        1048576 edbres00001.jrs
-a----         2020/11/4     23:44        1048576 edbres00002.jrs
-a----        2020/12/10      0:06        1048576 edbtmp.log
-a----        2020/12/10      0:06          16384 secedit.jfm
-a----        2020/12/10      9:00        1048576 secedit.sdb
WeiyiGeek.secedit.sdb
WeiyiGeek.secedit.sdb

WeiyiGeek.secedit.sdb

基础语法:

代码语言:javascript
复制
# 语法格式:
secedit [/configure | /analyze | /import | /export | /validate | /generaterollback]

# 参数说明:
/quit 安静模式

/export

描述:允许你导出保存在数据库中的安全设置。

基础语法:

代码语言:javascript
复制
# 语法:
secedit /export [/db filename] [/mergedpolicy] /cfg filename [/areas area1 area2...] [/log filename]

# 参数:
/db filename - 指定要导出数据的数据库。如果没有指定,将使用系统安全数据库。
/cfg filename - 指定要导出数据库内容的安全模板。
/mergedpolicy - 合并并且导出域和本地策略安全设置。
/areas - 指定要应用到系统的安全性范围。如果没有指定此参数,在数据库中定义的所有安全性设置都将应用到系统中。 要配置多个范围,用空格将它们分开。下列安全性范围是受支持的:
  * SECURITYPOLICY - 包括帐户策略,审核策略,事件日志设置和安全选项。
  * GROUP_MGMT - 包括受限制的组设置
  * USER_RIGHTS - 包括用户权限分配
  * REGKEYS - 包括注册表权限
  * FILESTORE - 包括文件系统权限
  * SERVICES - 包括系统服务设置
/log filename - 指定要记录导出操作状态的文件。

/configure

描述: 允许你用保存在数据库中的安全性设置来配置系统。

基础语法:

代码语言:javascript
复制
secedit /configure /db filename [/cfg filename] [/overwrite][/areas area1 area2...] [/log filename] [/quiet]

/overwrite - 指定在导入安全性模板前数据库应该被清空
# - 如果没有指定此参数在安全性模板中指定的将累积到数据库中。
# - 如果没有指定此参数而且在数据库中的设置与要导入的模板冲突,将采用模板中的设置。

/import

描述: 可将安全性模板导入到数据库以便模板中指定的设置可应用到系统或作为分析系统的依据。

基础语法:

代码语言:javascript
复制
secedit /import /db FileName .sdb /cfg FileName.inf [/overwrite] [/areasArea1 Area2 ...] [/logFileName] [/quiet]

/analyze

描述: 可通过将其与数据库中的基本设置相比较,分析一台计算机上的安全设置。

代码语言:javascript
复制
secedit /analyze /db FileName.sdb [/cfgFileName] [/overwrite] [/logFileName] [/quiet]

/GenereateRollback

描述:在将配置模板应用到计算机上时可以选择创建回滚模板,该模板在应用时会将安全性设置重置为应用配置模板前的值。(可根据配置模板生成一个回滚模板)

代码语言:javascript
复制
secedit /generaterollback /cfg filename /rbk filename [/log filename] [/quiet]
/db filename - 指定执行复原操作使用的数据库。
/cfg filename - 指定一个将要生成关于它的复原模板的安全模板。安全模板是用安全模板管理单元创建的。
/rbk filename - 指定一个复原信息要写入的安全模板。安全模板是用安全模板管理单元创建的。

/validate

描述:验证要导入到分析数据库或系统应用程序的安全模板的语法,在不同的系统下执行配置文件中的参数是不同的;

基础语法:

代码语言:javascript
复制
secedit /validate FileName

常用实例:

代码语言:javascript
复制
# - 1..命令行组策略中本地安全策略进行导出
secedit /export /cfg secedit.inf /log secedit.log /quiet

# - 2.将修改的本地安全策略导入到系统之中(导入全案策略) 日志路径 gp.log 或者 %windir%\security\logs\scesrv.log。
secedit /configure /db gp.sdb /cfg secedit.inf /overwrite /log gp.log /quiet

# - 3.将安全性模板导入到数据库中存储为模板
secedit /import /db secedit.sdb /cfg secedit.inf
secedit /import /db hisecws.sdb /cfg hisecws.inf /overwrite 
  # 使用 /overwrite 模式中的这个模板配置当前系统会 导致指定数据库中现有的安全性记录丢失。你想继续这个操作吗? [y/n]

# - 4.验证secedit.cfg模板文件格式是否正确
SecEdit.exe /validate .\secedit.cfg
  # 模板 C:\Users\WeiyiGeek\secedit.cfg 已生效

# - 5.选择创建回滚模板
secedit /generaterollback /db hisecws.sdb /cfg hisecws.inf /rbk hisecwsrollback.inf /log hisecws.log

# - 6. 分析一台计算机上的安全设置
secedit /analyze /db current.sdb /log result.txt
  # 有关详细信息,请查看日志 result.txt。
WeiyiGeek.
WeiyiGeek.

WeiyiGeek.

Tips : Built-In Local Groups (本地内置组查询)

代码语言:javascript
复制
# Administrators组 *S-1-5-32-544
# Users组 *S-1-5-32-545
# GUESTS组 *S-1-5-32-546
# BUILTIN\ACCOUNT OPERATORS *S-1-5-32-548 (=0x224)
# UILTIN\SERVER OPERATORS *S-1-5-32-549 (=0x225)
# BUILTIN\PRINT OPERATORS *S-1-5-32-550 (=0x226)
# BUILTIN\BACKUP OPERATORS *S-1-5-32-551 (=0x227)
# BUILTIN\REPLICATOR  *S-1-5-32-552 (=0x228)

0x02 gpresult 命令 - 显示机器或用户的组策略信息

描述:Gpresult 显示机器或用户的组策略信息此命令行工具显示目标用户和计算机的策略结果集 (RSoP) 的信息

语法参数:

代码语言:javascript
复制
GPRESULT [/S system [/U username [/P [password]]]] [/SCOPE scope]
         [/USER targetusername] [/R | /V | /Z] [(/X | /H) <filename> [/F]]

#参数列表:
/S        system                 指定要连接到的远程系统。
/U       [domain\]user        指定命令应在其下执行的用户上下文,无法与 /X、/H 一起使用。
/P        [password]           为给定的用户上下文指定密码。如果省略则提示输入,无法与 /X、/H 一起使用。
/SCOPE    scope             指定是显示用户还是计算机设置,有效值: "USER","COMPUTER"。
/USER    [domain\]user    指定要显示 RSOP 的用户名称。
/R          显示 RSoP 摘要数据。
/V          指定要显示详细信息,详细信息提供已经应用的、优先权是 1 的详细设置。
/Z          指定显示超详细信息。超详细信息提供其他详细设置,用 1 或更高的优先权应用于此设置。这允许您查看是否在多处设置了某一设置。请参阅组策略联机帮助主题获得更多信息。
/X        <filename>      以 XML 格式将报告保存该位置,并使用由<filename> 参数指定的文件名。(在 Windows Vista SP1 和更高版本以及 Windows Server 2008高版本中有效)
/H        <filename>      以 HTML 格式将报告保存该位置,并使用由 <filename> 参数指定的文件名。(在 WindowsVista SP1 和更高版本以及 Windows Server 2008高版本中有效)

/F         强制 gpresult 覆盖在, /X 或 /H 命令中指定的文件名

基础实例:

代码语言:javascript
复制
# 1.显示更多安装策略信息
gpresult /scope USER /z
已应用的组策略对象
-------------------
本地组策略

用户是下列安全组的一部分
------------------------
None
Everyone
本地帐户和管理员组成员
BUILTIN\Administrators
BUILTIN\Users
NT AUTHORITY\INTERACTIVE
控制台登录
NT AUTHORITY\Authenticated Us
This Organization
本地帐户
LOCAL
NTLM Authentication
High Mandatory Level

用户有下列安全特权
------------------
绕过遍历检查
管理审核和安全日志
备份文件和目录
还原文件和目录
更改系统时间
关闭系统
从远程系统强制关机
取得文件或其他对象的所有权
调试程序
修改固件环境值
配置文件系统性能
配置文件单个进程
提高计划优先级
加载和卸载设备驱动程序
创建一个页面文件
为进程调整内存配额
从扩展坞上取下计算机
执行卷维护任务
身份验证后模拟客户端
创建全局对象
更改时区
创建符号链接
增加进程工作集

# 2.查看本地用户策略组信息
GPRESULT /USER targetusername /V

# 3.远程机器用户的策略组信息
GPRESULT /S system /U username /P password /SCOPE USER /V

# 4.显示RsoP操作系统组策略结果
gpresult /r

# 5.将报告进行HTML导出
GPRESULT /H GPReport.html
WeiyiGeek.
WeiyiGeek.

WeiyiGeek.

Tips: 附录脚本合规检查采用Bat方式,推荐使用博主的PowerShell进行合规检测。

代码语言:javascript
复制
 if exist no.txt (del no.txt)
cls
echo 正在进行 "审计与帐户策略” 安全检查
echo > list.txt PasswordComplexity = 1
echo >> list.txt MinimumPasswordLength = 8
echo >> list.txt MaximumPasswordAge = 42
echo >> list.txt MinimumPasswordAge = 1
echo >> list.txt PasswordHistorySize = 5
echo >> list.txt ClearTextPassword = 0
echo >> list.txt ResetLockoutCount = 15
echo >> list.txt LockoutDuration = 15
echo >> list.txt LockoutBadCount = 15
echo >> list.txt AuditPolicyChange = 3
echo >> list.txt AuditLogonEvents = 3
echo >> list.txt AuditObjectAccess = 3
echo >> list.txt AuditPrivilegeUse = 0
echo >> list.txt AuditProcessTracking = 0
echo >> list.txt AuditDSAccess = 0
echo >> list.txt AuditSystemEvents = 3
echo >> list.txt AuditAccountLogon = 3
echo >> list.txt AuditAccountManage = 3

secedit /export /cfg model.inf >nul

for /F "tokens=1,3" %%i in (list.txt) do (
call :Getgp %%i %%j
)
ping 127.0.0.1 /n 2 >nul
del tmp.txt
del list.txt
del model.inf
goto :EOF
:Getgp
find "%1" model.inf >tmp.txt
for /f "skip=2 tokens=3" %%i in (tmp.txt) do (
if "%%i”==”%2" (echo %1=%%i ok) else (echo %1 策略不符合规则>>bad.txt)
)

goto :EOF

补充说明:


0x0n 入坑&出坑

1.修改本地安全设置的ini文件后采用secedit导入本地安全策略出现了扩展性错误。

错误表现: 1) 服务器查看相关的安全性策略的配置,发现修改某一个设置后通过本地的gpedit.msc打开本地安全策略就报了这个错误 2) 在SecEdit.exe /validate secconfig.cfg验证我们修改过的文件.

代码语言:javascript
复制
PS C:\Users\WeiyiGeek> SecEdit.exe /validate secconfig.cfg
出现了扩展错误。
 你指定的文件可能已损坏。
WeiyiGeek.出现了扩展性错误
WeiyiGeek.出现了扩展性错误

WeiyiGeek.出现了扩展性错误

问题原因: 我修改后的secconfig.cfg策略文件其编码是UTF-8而非 UTF-16 LE格式。

解决办法: 1) 手动将内容复制到secedit /export /cfg config.cfg /quiet生成的config.cfg 2) 采用PS不指定编码格式Get-Content secconfig.cfg | Out-File test.cfg

代码语言:javascript
复制
# - 针对于修改服务器相关的安全性策略的配置后出现了扩展性错误解决办法

# 方式1.用以下命令来检测修复(百度-未实践)
  * esentutl /k %windir%\Security\Database\Secedit.sdb 
  * esentutl /g %windir%\Security\Database\Secedit.sdb
  * esentutl /p %windir%\Security\Database\Secedit.sdb 

# 方式2.重新生成安全数据库的方法
  * 1.Open the %SystemRoot%\Security folder, create a new folder, and then name it "OldSecurity". 
  * 2.Move all of the files ending in .log from the %SystemRoot%\Security folder to the OldSecurity folder. 
  * 3.Find the Secedit.sdb file in the %SystemRoot%\Security\Database folder, and then rename this file to "Secedit.old". 
  * 4.Click Start, click Run, type mmc, and then click OK. 
  * 5.Click Console, click Add/Remove Snap-in, and then add the Security and Configuration snap-in. 
  * 6.Right-click Security and Configuration and Analysis, and then click Open Database. 
  * 7.Browse to the %SystemRoot%\Security\Database folder, type Secedit.sdb in the File name box, and then click Open. 
  * 8.When you are prompted to import a template, click Setup Security.inf, and then click Open.
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-05-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 0x01 secedit 命令 - 命令行中操作组策略计算机安全策略
    • /export
      • /configure
        • /import
          • /analyze
            • /GenereateRollback
              • /validate
              • 0x02 gpresult 命令 - 显示机器或用户的组策略信息
              • 0x0n 入坑&出坑
                • 1.修改本地安全设置的ini文件后采用secedit导入本地安全策略出现了扩展性错误。
                相关产品与服务
                数据库
                云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档