sc命令解析与实例使用

2022-09-28 19:27:45 浏览数 (1)

[TOC]

0x00 基础语法

描述:SC 命令是用于与服务控制管理器通信的命令行程序.

语法参数:

代码语言:javascript复制
sc <server> [command] [service name] <option1> <option2>   #选项 <server> 的格式为 "\ServerName"
sc <server> config [service name] <option1> <option2>

#sc二级命令
query-----------查询服务的状态,或枚举服务类型的状态。
queryex---------查询服务的扩展状态,或枚举服务类型的状态。
start-----------启动服务。
pause-----------向服务发送 PAUSE 控制请求。
interrogate-----向服务发送 INTERROGATE 控制请求。
continue--------向服务发送 CONTINUE 控制请求。
stop------------向服务发送 STOP 请求。
config----------更改服务的配置(永久)。
description-----更改服务的描述。
failure---------更改服务失败时执行的操作。
failureflag-----更改服务的失败操作标志。
sidtype---------更改服务的服务 SID 类型。
privs-----------更改服务的所需权限。
qc--------------查询服务的配置信息。
qdescription----查询服务的描述。
qfailure--------查询失败时服务执行的操作。
qfailureflag----查询服务的失败操作标志。
qsidtype--------查询服务的服务 SID 类型。
qprivs----------查询服务的所需权限。
qtriggerinfo----查询服务的触发器参数。
qpreferrednode--查询首选的服务 NUMA 节点。
delete----------(从注册表)删除服务。
create----------创建服务(将其添加到注册表)。
control---------向服务发送控制。
sdshow----------显示服务的安全描述符。
sdset-----------设置服务的安全描述符。
showsid---------显示相应于假定名称的 SID 字符串。
triggerinfo-----配置服务的触发器参数。
preferrednode---设置首选的服务 NUMA 节点。
GetDisplayName--获取服务的 DisplayName
GetKeyName------获取服务的 ServiceKeyName。
EnumDepend------枚举服务的依存关系。

Tips : 在 PowerShell 中sc 是 cmdlet Set-Content 的别名,应该这样使用加上 .exe 才能正常使用。

0x01 sc 命令

create

描述: 创建一个自启/手动开启服务并写入注册表之中;

代码语言:javascript复制
用法:sc <server> create [service name] [binPath= ] <option1> <option2>...

#注意: 选项名称包括等号。等号和值之间需要一个空格。
type= <own|share|interact|kernel|filesys|rec|userown|usershare>
      (默认 = own)
start= <boot|system|auto|demand|disabled|delayed-auto>
      (默认 = demand)
error= <normal|severe|critical|ignore>
      (默认 = normal)
binPath= <.exe 文件的 BinaryPathName>
group= <LoadOrderGroup>
tag= <yes|no>
depend= <依存关系(以 / (斜杠)分隔)>
obj= <AccountName|ObjectName>
      (默认= LocalSystem)
DisplayName= <显示名称>
password= <密码>

实例案例:

代码语言:javascript复制
# 安装服务:NewService为创建的服务名,binPath后面是运行exe文件的所在路径
sc create NewService binPath="C:Debugwin32srvDemo.exe"  

# 服务自动开启某个程序(type共享,start启动方式自动,displayname服务显示名称描述)
sc create NewService binPath= "D:Debugstart1.bat -config 1.ini" type=share start= "auto" displayname= "BWJXServices"

# Prometheus Metrics Windows Nodes Services 
sc create prometheus_windows_exporter_service binPath= "d:prowindows_exporter-0.16.0-amd64.exe --config.file=d:proconfig.yml" start= "auto" displayname= "prometheus_windows_exporter_service"

config

描述:配置服务启动方式或者禁用服务,它有三种状态AUTO/DEMAND/DISABLED;

基础案例:

代码语言:javascript复制
#设置服务的集中方式
sc config 服务名 start= AUTO       (自动)
sc config 服务名 start= DEMAND     (手动)
sc config 服务名 start= DISABLED   (禁用)

#将智能卡服务禁用
sc config SCardSvr start= disabled
sc config SCPolicySvc start= disabled

#在XP系统中开机便会自动启动:
sc config test3 start=AUTO

start

描述:用来开启已存在的服务

用法参数:

代码语言:javascript复制
```

**基础案例:**
```bash
sc start NewService

stop

描述:用来停止已开启的服务

用法参数:

代码语言:javascript复制
```

**基础案例:**
```bash
sc stop NewService

delete

描述:用来删除已存在的服务

基础语法:

代码语言:javascript复制
sc delete NewService

基础案例:

代码语言:javascript复制
sc delete "Service Name"

qc

描述:查询服务的配置信息 (dependencies 依赖)

代码语言:javascript复制
sc qc NewService

基础案例:

代码语言:javascript复制
sc qc Spooler
sc qc upnphost

WeiyiGeek.

0x02 入坑&出坑

问题1.在注册***WinService服务时,再使用 “sc delete 服务器名称” 命令删除服务就出现“指定的服务已经标记为删除”的异常。

问题原因:出现上述原因是运行删除服务项命令的时候,服务管理窗口未关闭引起的。 解决办法: 关闭服务管理窗口,重新删除、安装服务项即可。

0 人点赞