Solved

Please enter a computer name (running batch file from hta)

Posted on 2009-07-01
7
452 Views
Last Modified: 2012-08-14
Hi guys,
I currently have the following batch file that works great.

Usage is:
script.bat [computer_name]

========================================= script.bat
@echo off

if [%1]==[] (
echo useage: script [computer_name]
echo         Please enter a computer name before running.
goto :eof
)

echo Checking the following 4 services on a machine %1 .....
 
rem check_services.bat <computername>
for /f "tokens=1-6 delims=[.] " %%a in ('ping %1 -n 1 ^| find "["') do set ip=%%c.%%d.%%e.%%f
ping -n 1 %1 >nul 2>&1
if %errorlevel%==0 (
   echo %1 [%ip%]: Up
) else (
   echo %1 [%ip%]: Down
)
echo sc \\%ip% query alerter
sc \\%ip% query alerter
sc \\%ip% query browser
sc \\%ip% query server

rem ============================ end of file

What id like to do is run the same thing but just in a hta window.

=============================================== script.hta

Please enter a computer name __________________  <Go>

Output seen in the hta as if running it from command line.

===================================== end of hta

Any help greatly appreciated.
========================================= script.bat
@echo off
 
if [%1]==[] (
echo useage: script [computer_name]
echo         Please enter a computer name before running.
goto :eof
)
 
echo Checking the following 4 services on a machine %1 .....
 
rem check_services.bat <computername>
for /f "tokens=1-6 delims=[.] " %%a in ('ping %1 -n 1 ^| find "["') do set ip=%%c.%%d.%%e.%%f
ping -n 1 %1 >nul 2>&1
if %errorlevel%==0 (
   echo %1 [%ip%]: Up
) else (
   echo %1 [%ip%]: Down
)
echo sc \\%ip% query alerter
sc \\%ip% query alerter
sc \\%ip% query browser
sc \\%ip% query server
 
rem ============================ end of file

Open in new window

0
Comment
Question by:Simon336697
  • 5
  • 2
7 Comments
 
LVL 3

Expert Comment

by:astroviper
ID: 24759652
Using: http://www.experts-exchange.com/Web_Development/Web_Languages-Standards/Q_20709676.html

Have script.bat in the same location as the hta.

<html>
<head>
<HTA:APPLICATION ID="oHTA"
      VERSION="1.0"
     APPLICATIONNAME="BatchFile"
     BORDER="thin"
     BORDERSTYLE="normal"
     CAPTION="yes"
     CONTEXTMENU="no"
     ICON=""
     INNERBORDER="yes"
     MAXIMIZEBUTTON=no"
     MINIMIZEBUTTON="no"
     NAVIGABLE="yes"
     SCROLL="no"
     SCROLLFLAT="yes"
     SELECTION="yes"
     SHOWINTASKBAR="yes"
     SINGLEINSTANCE="yes"
     SYSMENU="yes"
     WINDOWSTATE="normal"
/>
 
<script language="VBScript">
 
Dim objShell
Const ForReading = 1
 
Sub Run(Name)
	Set objShell = CreateObject("WScript.Shell")
	Return = objShell.Run(Name, 1, true)
	Set objFSO = CreateObject("Scripting.FileSystemObject")
	Set objInput = objFSO.OpenTextFile("out.txt", ForReading)
	DataArea.InnerHTML = "<pre>" & objInput.ReadAll & "</pre>"
	objInput.Close
	objFSO.DeleteFile "out.txt"
End Sub
 
</script>
 
</head>
<body>
 
<a href="javascript:Run('script.bat > out.txt');">Hello</a><br>
<span id="DataArea"></span>
 
</body>
</html>

Open in new window

0
 
LVL 3

Expert Comment

by:astroviper
ID: 24759655
Wait, I missed a bit, give me a min.
0
 
LVL 3

Expert Comment

by:astroviper
ID: 24759698
Apologies for the double posting

<html>
<head>
<HTA:APPLICATION ID="oHTA"
      VERSION="1.0"
     APPLICATIONNAME="BatchFile"
     BORDER="thin"
     BORDERSTYLE="normal"
     CAPTION="yes"
     CONTEXTMENU="no"
     ICON=""
     INNERBORDER="yes"
     MAXIMIZEBUTTON=no"
     MINIMIZEBUTTON="no"
     NAVIGABLE="yes"
     SCROLL="no"
     SCROLLFLAT="yes"
     SELECTION="yes"
     SHOWINTASKBAR="yes"
     SINGLEINSTANCE="yes"
     SYSMENU="yes"
     WINDOWSTATE="normal"
/>
 
<script language="VBScript">
 
Dim objShell
Const ForReading = 1
 
Sub Run
	Name = "script.bat " & comp.value & " > out.txt"
	Set objShell = CreateObject("WScript.Shell")
	Return = objShell.Run(Name, 1, true)
	Set objFSO = CreateObject("Scripting.FileSystemObject")
	Set objInput = objFSO.OpenTextFile("out.txt", ForReading)
	DataArea.InnerHTML = DataArea.InnerHTML & "<pre>" & objInput.ReadAll & "</pre><br>"
	objInput.Close
	objFSO.DeleteFile "out.txt"
End Sub
 
</script>
 
</head>
<body>
 
Please enter a computer name <input type="text" name="comp">
<input type="button" Value="Go" onClick="Run"><br>
<span id="DataArea"></span>
 
</body>
</html>

Open in new window

0
Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

 
LVL 3

Expert Comment

by:astroviper
ID: 24759715
Actually you might wanna change the SCROLL="no" to a yes. I set it up so you can run it multiple times and it appends to the last command.
0
 
LVL 1

Author Comment

by:Simon336697
ID: 24761608
Hi astro,
Youre a gun.
astro....last one.

Is there any way to add:
1) The abilty to refresh the hta? At the moment, you cant it seems.
2) The ability to hide the command window when you click on the Go button.

Really appreciate your help.
0
 
LVL 3

Accepted Solution

by:
astroviper earned 500 total points
ID: 24761851
I only tested it on a a batch file with "echo hello" in it so it was pretty much instantaneous. Maybe your one requires the right environment to run in as the output i get is:
C:\Users\Mike\Desktop>script.bat
C:\Users\Mike\Desktop>script.bat
C:\Users\Mike\Desktop>script.bat
... times 1000's

<html>
<head>
<HTA:APPLICATION ID="oHTA"
     VERSION="1.0"
     APPLICATIONNAME="BatchFile"
     BORDER="thin"
     BORDERSTYLE="normal"
     CAPTION="yes"
     CONTEXTMENU="yes"
     ICON=""
     INNERBORDER="yes"
     MAXIMIZEBUTTON="yes"
     MINIMIZEBUTTON="yes"
     NAVIGABLE="yes"
     SCROLL="yes"
     SCROLLFLAT="yes"
     SELECTION="yes"
     SHOWINTASKBAR="yes"
     SINGLEINSTANCE="no"
     SYSMENU="yes"
     WINDOWSTATE="normal"
/>
 
<script language="VBScript">
 
Dim objShell
Const ForReading = 1
temp = "out.txt"
 
Sub Run
        Name = "script.bat " & comp.value & " > " & temp
        Set objShell = CreateObject("WScript.Shell")
        Return = objShell.Run(Name, 0, true)
        Refresh
        Set objFSO = CreateObject("Scripting.FileSystemObject")
        objFSO.DeleteFile temp
End Sub
 
Sub Refresh
        Set objFSO = CreateObject("Scripting.FileSystemObject")
        If objFSO.FileExists(temp) Then
            Set objInput = objFSO.OpenTextFile(temp, ForReading)
            output = objInput.ReadAll
            If Not output = "" Then DataArea.InnerHTML = "<pre>" & output & "</pre><br>"
            objInput.Close
        End If
End Sub
 
</script>
 
</head>
<body>
 
Please enter a computer name <input type="text" name="comp">
<input type="submit" Value="Go" onClick="Run">
<input type="button" Value="Refresh" onClick="Refresh"><br>
<span id="DataArea"></span>
 
</body>
</html>

Open in new window

0
 
LVL 1

Author Comment

by:Simon336697
ID: 24783872
Thanks so much astro!
0

Featured Post

Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I met Paul Devereux (@pdevereux) today when I responded to his tweet asking “Anybody know how to automate adding files from disk to a folder in #outlook  ?”.  I replied back and told Paul that using automation, in this case scripting, to add files t…
Introduction During my participation as a VBScript contributor at Experts Exchange, one of the most common questions I come across is this: "I have a script that runs against only one computer. How can I make it run against a list of computers in …
Windows 10 is mostly good. However the one thing that annoys me is how many clicks you have to do to dial a VPN connection. You have to go to settings from the start menu, (2 clicks), Network and Internet (1 click), Click VPN (another click) then fi…
The Email Laundry PDF encryption service allows companies to send confidential encrypted  emails to anybody. The PDF document can also contain attachments that are embedded in the encrypted PDF. The password is randomly generated by The Email Laundr…

776 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question