ログオフまたはタイムアウトすると、HTA は再起動スクリプトを実行してから終了します。再起動スクリプトは、MSHTA プロセスがなくなるのを待ってから、再起動して終了します。
これを行うには、WMI を使用して実行中のプロセスをスキャンし、コマンド ライン パラメータに HTA の名前が含まれている MSHTA.EXE のインスタンスを探します。
これを示す小さな例を次に示します。
これはベアボーン HTA です。RestartTest.hta として保存します。
<html> <!-- RestartTest.hta -->
<head>
<title>Self Restarting HTA Test</title>
<script language="VBScript">
sub RunApp(sApp)
CreateObject("WScript.Shell").Run(sApp)
end sub
sub LogOff()
RunApp "cscript.exe RestartHTA.vbs"
MsgBox "simulating delayed exit - click to close"
window.close()
end sub
</script>
</head>
<body >
<input type="button" value="Log off" onClick="LogOff()" />
</body>
</html>
これは再起動スクリプトで、RestartHTA.vbs として保存されます。
' RestartHTA.vbs'
' wait until RestartTest.hta is not running and restart it.'
MSHTA = "mshta.exe"
sHTA = "RestartTest.hta"
say "waiting for process " & MSHTA & " with param " & sHTA & " to end"
secs = 2000
bRunning = vbTrue
do while bRunning
if ProcessRunning(MSHTA, sHTA) then
say "still running, wait a few seconds"
WScript.Sleep secs
else
bRunning = vbFalse
end if
loop
say "HTA not found, proceding to restart"
WScript.Sleep secs
CreateObject("WScript.Shell").Run(sHTA)
WScript.Quit
'---'
function ProcessRunning(sProcess, sParam)
set oWMI = GetObject( _
"winmgmts:{impersonationLevel=impersonate}!\\.\root\cimv2")
set cProcs = oWMI.ExecQuery( _
"select * from Win32_Process where Name = '" & sProcess & "'")
bFound = vbFalse
for each oProc in cProcs
say oProc.Name & ": " & oProc.CommandLine
if (InStr(oProc.CommandLine, sParam) > 0) then
say "found"
bFound = vbTrue
else
say "wrong param"
end if
next
ProcessRunning = bFound
end function
sub Say(s)
WScript.Echo s
end sub
'==='
いずれかを実行してサイクルを開始し、X ボタンで HTA を閉じて中断することができます。CScript を使用して再起動スクリプトを明示的に実行していることに注意してください。これは、デモ目的でコンソール出力を表示するためのものです (また、何らかの理由で CScript をマシンのデフォルトとして設定および維持するのに問題があるため)。