我愛我的家園!

          成功在于你是否努力,希望在于你是否相信自己!

           

          SC命令|SC語法

          如果要刪除一個系統服務,可以使用 SC delete [服務名稱],比如
          刪除messager服務,輸入SC DELETE MESSAGER。

          ?

          SC使用這樣的語法:

          1. SC [Servername] command Servicename [Optionname= Optionvalue]
          2. SC [command]

          這里使用第一種語法使用SC,使用第二種語法顯示幫助。

          下面介紹各種參數。

          Servername
          可選擇:可以使用雙斜線,如
          \\myserver ,也可以是 \\192.168.0.1 來操作遠程計算機。如果在本地計算機上操作

          就不用添加任何參數。

          Command
          下面列出SC可以使用的命令。
          config----改變一個服務的配置。(長久的)
          continue--對一個服務送出一個繼續控制的要求。
          control----對一個服務送出一個控制。
          create----創建一個服務。(增加到注冊表中)
          delete----刪除一個服務。(從注冊表中刪除)
          EnumDepend--列舉服務的從屬關系。
          GetDisplayName--獲得一個服務的顯示名稱。
          GetKeyName--獲得一個服務的服務鍵名。
          interrogate--對一個服務送出一個詢問控制要求。
          pause----對一個服務送出一個暫停控制要求。
          qc----詢問一個服務的配置。
          query----詢問一個服務的狀態,也可以列舉服務的狀態類型。
          start----啟動一個服務。
          stop----對一個服務送出一個停止的要求。

          Servicename
          在注冊表中為service key制定的名稱。注意這個名稱是不同于顯示名稱的(這個名稱可以用net start和服務控制面板看到),而SC是使用服務鍵名來鑒別服務的。

          Optionname
          這個optionname和optionvalue參數允許你指定操作命令參數的名稱和數值。注意,這一點很重要在操作名稱和等號之間是沒有空格的一開始我不知道,結果………………,比如,start= Optionvalue,這個很重要。

          optionvalue可以是0,1,或者是更多的操作參數名稱和數值對。
          如果你想要看每個命令的可以用的optionvalue,你可以使用sc command這樣的格式。這會為你提供詳細的幫助。

          Optionvalue
          為optionname的參數的名稱指定它的數值。有效數值范圍常常限制于哪一個參數的optionname。如果要列表請用sc command來詢問每個命令。

          說明:
          很多的命令需要管理員權限,所以我想說,在你操作這些東西的時候最好是管理員。呵呵!
          當你鍵入SC而不帶任何參數時,SC.exe會顯示幫助信息和可用的命令。當你鍵入SC緊跟著命令名稱時,你可以得 到一個有關這個命令的詳細列表。比如,鍵入sc create可以得到和create有關的列表。
          但是除了一個命令,sc query,這會導出該系統中當前正在運行的所有服務和驅動程序的狀態。
          當你使用start命令時,你可以傳遞一些參數(arguments)給服務的主函數,但是不是給服務進程的主函數。

          ?

          SC create
          這個命令可以在注冊表和服務控制管理數據庫建立一個入口。

          語法:
          sc [servername] create Servicename [Optionname= Optionvalue]
          這里的servername,servicename,optionname,optionvalue和上面的一樣,這里就不多說了。
          這里我們詳細說明一下optionname和optionvalue。

          Optionname--Optionvalue
          描述:
          type=----own, share, interact, kernel, filesys
          關于建立服務的類型,選項值包括驅動程序使用的類型,默認是share。
          start=----boot, system, auto, demand, disabled
          關于啟動服務的類型,選項值包括驅動程序使用的類型,默認是demand(手動)。
          error=----normal, severe, critical, ignore
          當服務在導入失敗錯誤的嚴重性,默認是normal。
          binPath=--(string)
          服務二進制文件的路徑名,這里沒有默認值,這個字符串是必須設置的。
          group=----(string)
          這個服務屬于的組,這個組的列表保存在注冊表中的ServiceGroupOrder下。默認是nothing。
          tag=----(string)
          如果這個字符串被設置為yes,sc可以從CreateService call中得到一個tagId。然而,SC并不顯示這個標簽,所以使用這個沒有多少意義。默認是nothing
          depend=----(space separated string)有空格的字符串。
          在這個服務啟動前必須啟動的服務的名稱或者是組。
          obj=----(string)
          賬號運行使用的名稱,也可以說是登陸身份。默認是localsystem
          Displayname=--(string)
          一個為在用戶界面程序中鑒別各個服務使用的字符串。
          password=--(string)
          一個密碼,如果一個不同于localsystem的賬號使用時需要使用這個。

          Optionvalue
          Optionname參數名稱的數值列表。參考optionname。當我們輸入一個字符串時,如果輸入一個空的引用這意味著一個空的字符串將被導入。

          說明:
          The SC CREATE command performs the operations of the CreateService API function.
          這個sc create命令執行CreateService API函數的操作。詳細請見CreateService。

          例1:
          下面這個例子在一臺叫做(
          \\myserver )的計算機上為一個叫“NewService”的服務建立的一個注冊表登記。
          sc
          \\myserver create NewService binpath= c:\winnt\system32\NewServ.exe
          按照默認,這個服務會建立一個WIN32_SHARE_PROCESS使用SERVICE_DEMAND_START啟動方式。這將不會有任何從屬關系,也將會按照localsystem安全上下關系來運行。

          例2:
          下面這個例子將在本地計算機上,建立一個服務,它將會是一個自動運行服務,并且運行在他自己的進程上。它從屬于TDI組和NetBios服務上。注意,你必須在從屬中間增加一個空格的引用。
          sc create NewService binpath= c:\winnt\system32\NewServ.exe type= own
          start= auto depend= "+TDI Netbios"

          例3:
          服務開發者可以通過臨時改變二進制路徑(影像路徑)的方式來將這個服務運行在內核調試器的上下關系中。下面這個例子就可以讓我們看到如何改變服務的配置。
          sc config NewService binpath= "ntsd -d c:\winnt\system32\Newserv.exe"
          這個例子會引起服務控制管理器調用ntsd.exe使用下例的參數字符串:
          "-d c:\nt\system32\NewServ.exe"
          當系統裝入newserv.exe時ntsd將會轉而打斷調試器,所以斷點可以被設置在服務代碼里。

          ?

          SC QC
          這個SC QC“詢問配置”命令可以列出一個服務的配置信息和QUERY_SERVICE_CONFIG結構。

          語法:
          sc [Servername] qc Servicename [Buffersize] Parameters
          servername和servicename前面已經介紹過了,這里不再多說。
          Buffersize,可選擇的,列出緩沖區的尺寸。

          說明:
          SC QC命令顯示了QUERY_SERVICE_CONFIG結構的內容。

          以下是QUERY_SERVICE_CONFIG相應的區域。
          TYPE------dwServiceType
          START_TYPE----dwStartType
          ERROR_CONTROL----dwErrorControl
          BINARY_PATH_NAME--lpBinaryPathName
          LOAD_ORDER_GROUP--lpLoadOrderGroup
          TAG------dwTagId
          DISPLAY_NAME----lpDisplayName
          DEPENDENCIES----lpDependencies
          SERVICE_START_NAME--lpServiceStartName

          例1:
          下面這個例子詢問了在上面例子中建立的“NewService”服務的配置:
          sc
          \\myserver qc NewService

          sc顯示下面的信息:

          SERVICE_NAME: NewService
          TYPE : 20 WIN32_SHARE_PROCESS
          START_TYPE : 3 DEMAND_START
          ERROR_CONTROL : 1 NORMAL
          BINARY_PATH_NAME : c:\winnt\system32\NewServ.exe
          LOAD_ORDER_GROUP :
          TAG : 0
          DISPLAY_NAME : NewService
          DEPENDENCIES :
          SERVICE_START_NAME : LocalSystem

          NewService有能力和其他的服務共享一個進程。但是它不是自動啟動的。二進制文件名是NewServ.exe。這個服務不依靠與其它的的服務,而且運行在lcoalsystem的安全上下關系中。這些都是調用QueryServiceStatus基本的返回,如果還需要更多的細節屆時,可以看看API函數文件。

          ?

          SC QUERY
          SC QUERY命令可以獲得服務的信息。

          語法:
          sc [Servername] query { Servicename | Optionname= Optionvalue... }

          參數:
          servername, servicename, optionname, optionvalue不在解釋。只談一下這個命令提供的數值。

          Optionname--Optionvalue
          描述:
          type=----driver, service, all
          列舉服務的類型,默認是service
          state=----active, inactive, all
          列舉服務的狀態,默認是active
          bufsize=--(numeric value)
          列舉緩沖區的尺寸,默認是1024 bytes
          ri=----(numeric value)
          但開始列舉時,恢復指針的數字,默認是0

          Optionvalue
          同上。

          說明:
          SC QUERY命令可以顯示SERVICE_STATUS結構的內容。

          下面是SERVICE_STATUS結構相應的信息:
          TYPE------dwServiceType
          STATE------dwCurrentState, dwControlsAccepted
          WIN32_EXIT_CODE----dwWin32ExitCode
          SERVICE_EXIT_CODE--dwServiceSpecificExitCode
          CHECKPOINT----dwCheckPoint
          WAIT_HINT----dwWaitHint
          在啟動計算機后,使用SC QUERY命令會告訴你是否,或者不是一個啟動服務的嘗試。如果這個服務成功啟動,WIN32_EXIT_CODE區間會將會包含一個0,當嘗試不成功時,當它意識到這個服務不能夠啟動時,這個區間也會提供一個退出碼給服務。

          例子:
          查詢“NewService"服務狀態,鍵入:
          sc query NewService

          顯示一下信息:

          SERVICE_NAME: NewService
          TYPE : 20 WIN32_SHARE_PROCESS
          STATE : 1 STOPPED
          (NOT_STOPPABLE,NOT_PAUSABLE,IGNORES_SHUTDOWN)
          WIN32_EXIT_CODE : 1077 (0x435)
          SERVICE_EXIT_CODE : 0 (0x0)
          CHECKPOINT : 0x0
          WAIT_HINT : 0x0

          注意,這里存在一個給這個服務的退出碼,即使這個服務部不在運行,鍵入net helpmsg 1077,將會得到對1077錯誤信息的說明:
          上次啟動之后,仍未嘗試引導服務。
          所以,這里我想說一句,希望大家可以活用net helpmsg,這會對你的學習有很大的幫助。

          下面在對SC query的命令在說明一下:
          列舉活動服務和驅動程序狀態,使用以下命令:
          sc query
          顯示messenger服務,使用以下命令:
          sc query messenger
          只列舉活動的驅動程序,使用以下命令:
          sc query type= driver
          列舉Win32服務,使用以下命令:
          sc query type= service
          列舉所有的服務和驅動程序,使用以下命令:
          sc query state= all
          用50 byte的緩沖區來進行列舉,使用以下命令:
          sc query bufsize= 50
          在恢復列舉時使用index=14,使用以下命令:
          sc query ri=14
          列舉所有的交互式服務,使用以下命令:
          sc query type= service type= interact

          posted on 2008-04-20 18:53 死神 閱讀(711) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           

          導航

          統計

          公告

          歡迎大家來到我的個人世界!

          常用鏈接

          留言簿(3)

          隨筆分類(5)

          隨筆檔案(9)

          文章分類(37)

          文章檔案(41)

          相冊

          語音技術

          最新隨筆

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 德保县| 西乌珠穆沁旗| 楚雄市| 白朗县| 西峡县| 天气| 牡丹江市| 古蔺县| 新蔡县| 洪江市| 常山县| 怀来县| 行唐县| 宣威市| 南宁市| 惠安县| 宜君县| 永丰县| 阿克苏市| 海南省| 大同县| 封开县| 锡林浩特市| 昂仁县| 行唐县| 揭阳市| 桃江县| 萨嘎县| 剑阁县| 呼图壁县| 兰州市| 沧源| 苏尼特右旗| 达孜县| 布拖县| 什邡市| 来安县| 游戏| 民乐县| 射洪县| 正蓝旗|