로그온 트리거 예제(스크립팅)
이 스크립팅 예제에서는 사용자가 로그온할 때 메모장을 실행하도록 예약된 작업을 만드는 방법을 보여 줍니다. 작업에는 시작할 작업의 시작 경계를 지정하는 로그온 트리거와 사용자를 지정하는 사용자 식별자가 포함됩니다. 작업은 관리자 그룹을 보안 컨텍스트로 사용하여 등록되어 작업을 실행합니다.
다음 절차에서는 지정된 사용자가 로그온할 때 시작할 메모장과 같은 실행 파일을 예약하는 방법을 설명합니다.
사용자가 로그온할 때 시작할 메모장을 예약하려면
- TaskService 개체를 만듭니다. 이 개체를 사용하면 지정된 폴더에 작업을 만들 수 있습니다.
- 작업 폴더를 가져와 작업을 만듭니다. TaskService.GetFolder 메서드를 사용하여 태스크가 저장된 폴더를 가져올 수 있고 TaskService.NewTask 메서드를 사용하여 작업을 나타내는 TaskDefinition 개체를 만듭니다.
- TaskDefinition 개체를 사용하여 작업에 대한 정보를 정의합니다. TaskDefinition.Settings 속성을 사용하여 작업 스케줄러 서비스가 작업을 수행하는 방법을 결정하는 설정을 정의하고 TaskDefinition.RegistrationInfo 속성을 사용하여 작업을 설명하는 정보를 정의합니다.
- TaskDefinition.Triggers 속성을 사용하여 로그온 트리거를 만듭니다. 이 속성은 TriggerCollection 개체에 대한 액세스를 제공합니다. TriggerCollection.Create 메서드(만들려는 트리거 유형 지정)를 사용하여 로그온 트리거를 만듭니다. 트리거를 만들 때 트리거의 시작 경계와 끝 경계를 설정하여 트리거를 활성화하고 비활성화합니다. 지정된 사용자가 시작 경계 후에 로그온할 때 작업의 작업이 실행되도록 트리거에 대한 UserId 속성을 설정해야 합니다.
- TaskDefinition.Actions 속성을 사용하여 실행할 태스크에 대한 작업을 만듭니다. 이 속성은 ActionCollection 개체에 대한 액세스를 제공합니다. ActionCollection.Create 메서드를 사용하여 만들려는 작업 유형을 지정합니다. 이 예제에서는 실행 파일을 시작하는 작업을 나타내는 ExecAction 개체를 사용합니다.
- TaskFolder.RegisterTaskDefinition 메서드를 사용하여 작업을 등록합니다. 이 예제에서는 관리자 그룹을 보안 컨텍스트로 사용하여 작업을 실행하도록 작업을 등록합니다.
다음 VBScript 예제에서는 사용자가 로그온할 때 메모장을 실행하도록 작업을 예약하는 방법을 보여 줍니다.
'---------------------------------------------------------
' This sample schedules a task to start notepad.exe when a user logs on.
'---------------------------------------------------------
' A constant that specifies a logon trigger.
const TriggerTypeLogon = 9
' A constant that specifies an executable action.
const ActionTypeExecutable = 0
'********************************************************
' Create the TaskService object.
Set service = CreateObject("Schedule.Service")
call service.Connect()
'********************************************************
' Get a folder to create a task definition in.
Dim rootFolder
Set rootFolder = service.GetFolder("\")
' The taskDefinition variable is the TaskDefinition object.
Dim taskDefinition
' The flags parameter is 0 because it is not supported.
Set taskDefinition = service.NewTask(0)
'********************************************************
' Define information about the task.
' Set the registration info for the task by
' creating the RegistrationInfo object.
Dim regInfo
Set regInfo = taskDefinition.RegistrationInfo
regInfo.Description = "Task will execute Notepad when a " & _
"specified user logs on."
regInfo.Author = "Author Name"
' Set the task setting info for the Task Scheduler by
' creating a TaskSettings object.
Dim settings
Set settings = taskDefinition.Settings
settings.StartWhenAvailable = True
'********************************************************
' Create a logon trigger.
Dim triggers
Set triggers = taskDefinition.Triggers
Dim trigger
Set trigger = triggers.Create(TriggerTypeLogon)
' Trigger variables that define when the trigger is active.
Dim startTime, endTime
startTime = "2006-05-02T10:49:02"
endTime = "2006-05-02T10:52:02"
WScript.Echo "startTime :" & startTime
WScript.Echo "endTime :" & endTime
trigger.StartBoundary = startTime
trigger.EndBoundary = endTime
trigger.ExecutionTimeLimit = "PT5M" ' Five minutes
trigger.Id = "LogonTriggerId"
trigger.UserId = "DOMAIN\UserName" ' Must be a valid user account
'***********************************************************
' Create the action for the task to execute.
' Add an action to the task. The action executes notepad.
Dim Action
Set Action = taskDefinition.Actions.Create( ActionTypeExecutable )
Action.Path = "C:\Windows\System32\notepad.exe"
WScript.Echo "Task definition created. About to submit the task..."
'***********************************************************
' Register (create) the task.
const createOrUpdateTask = 6
call rootFolder.RegisterTaskDefinition( _
"Test Logon Trigger", taskDefinition, createOrUpdateTask, _
"Builtin\Administrators", , 4)
WScript.Echo "Task submitted."
관련 항목