[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[网络连接] 批处理怎样监控网络流量并自动关机?

本帖最后由 ygqiang 于 2011-10-7 00:13 编辑

xp系统下,晚上  用迅雷下载高清视频,一开始有200KB/S的下载速度,有的时候,就突然没有速度了。(是通过web页面拨号上网的,如果断线,会自动重新拨号,这个时候,在30分钟以内,会重新拨号多次)

如果30分钟以后,仍然无法拨号成功(不能上网),就自动关机


2011-9-28最新需求如下:

开机,自动启动并监视迅雷,如果迅雷没有运行,则一直监视

如果迅雷已经运行了,则如果20分钟之内网络流量<20k(还要考虑遇到无法拨号成功的情况),就自动关机。


看33楼代码。


33楼vbs代码出现新问题。
这个vbs代码,正常情况下,如果检测到运行迅雷,在2分钟内,如果流量《20k,才会自动关机。

问题就是:运行迅雷(不下载),即使开qq  看在线视频,还会在2分钟内自动关机。
运行迅雷(不下载),一直开qq  看在线视频,在2分钟内,流量应该》20k,应该不会自动关机啊?

顶下,多谢各位啊。

TOP

顶下,期待高手来解决啊。

TOP

  1. @Echo Off
  2. :Loop
  3. Ping /n 1 www.bathome.net>nul||ShutDown /s /t 1
  4. MsHta JavaScript:document.write();setTimeout('close()',300000);
  5. Goto Loop
复制代码
不知道能否结合这个,实现所需要的效果呢?

TOP

  1. Dim WSH, WMI, EVN
  2. Set WSH = CreateObject("Wscript.Shell")
  3. Set WMI = GetObject("winmgmts:\\.\root\wmi")
  4. Set EVN = WMI.ExecNotificationQuery("Select * from MSNdis_StatusMediaDisconnect")
  5. Do While True
  6.         Set LatestEvent = EVN.NextEvent
  7.         WSH.Run("shutdown -s -t 0")
  8. Loop
复制代码
这个是lxzzr版主给出的vbs代码,功能是:如果出现断网就自动关机。

我的要求是:如果断网,等待30分钟左右,如果还不能联网,才关闭xp系统。

TOP

20# ygqiang


ping 不通时关机和当流量低于指定值时关机是完全不同的两个方向,你到底想要什么效果呢?求助时请先说明白自己需要的是什么,而不是让别人去猜测、判断
zm900612 发表于 2011-7-9 09:03



多谢。

我的意思是指:过30分钟,如果网络完全没有流量(网络掉线、完全断开,这个时候不能上网)的时候,自动关机。

TOP

  1. Dim WSH, WMI, CIM, EVD
  2. Set WSH = CreateObject("Wscript.Shell")
  3. Set WMI = GetObject("winmgmts:\\.\root\wmi")
  4. Set CIM = GetObject("winmgmts:\\.\root\cimv2")
  5. Set EVD = WMI.ExecNotificationQuery("Select * from MSNdis_StatusMediaDisconnect")
  6. Do While True
  7.     Set LatestEvent = EVD.NextEvent
  8.     Wscript.Echo "网络已经断开."
  9.         WScript.Sleep 1800000
  10.         Set Pings = CIM.ExecQuery("Select * From Win32_PingStatus where Address = 'www.baidu.com'")
  11.         For Each Ping in Pings
  12.                 If Ping.StatusCode = 0 Then
  13.                         Wscript.Echo "网络已经连接."
  14.                 Else
  15.                         WScript.Echo "关闭系统"
  16.                         Wscript.Echo WSH.Run("shutdown -s -t 6000")
  17.                 End If
  18.         Next
  19. Loop
复制代码
这是lxzzr版主给出的vbs代码。

不知道与zm900612 版主的bat代码,实现的功能是否一样呢?

TOP

顶下,有没有比较好的解决方法?谢谢

TOP

有没有人帮忙做下,谢谢

TOP

  1. On Error Resume Next
  2. Public CurrentFlowInt
  3. StrComputer = "."
  4. ConnectionID = "本地连接"
  5. '这里根据实际情况修改
  6. Set objWMIService = GetObject("winmgmts:" _
  7.     & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")
  8. Set colMonitoredProcesses = objWMIService. _        
  9.     ExecNotificationQuery("select * from __instancecreationevent " _
  10.         & " within 1 where TargetInstance isa 'Win32_Process'")
  11. i = 0
  12. Do While i = 0
  13.     Set objLatestProcess = colMonitoredProcesses.NextEvent
  14.     If objLatestProcess.TargetInstance.Name = "Thunder.exe" Then
  15. Wscript.Echo "迅雷已运行."
  16. Set ObjectWSH = CreateObject("Wscript.Shell")
  17. Set ObjectWMI = Getobject("winmgmts:\\" & StrComputer)
  18. Set NetCards = ObjectWMI.ExecQuery("Select * from Win32_NetworkAdapter WHERE NetConnectionID='" & ConnectionID & "'")
  19. If NetCards.count<>0 Then
  20. For Each NetCard In NetCards
  21. WScript.Echo "Name: " & NetCard.Name & " MACAddress: " & NetCard.MACAddress
  22. NetCardName = NetCard.Name
  23. strNet = Split(NetCard.Name, " ", -1, 1)
  24. str1 = strNet(0) & strNet(1) & strNet(2)
  25. Next
  26. Else
  27. Wscript.Echo "网卡不存在."
  28. WScript.Quit(0)
  29. End If
  30. '获取用于上网的网卡信息
  31. CurrentFlow
  32. BeginFlow = CurrentFlowInt
  33. '获取开始时接收的流量(字节)
  34. Wscript.Echo "BeginFlow: " & BeginFlow
  35. WScript.Sleep 120000
  36. '定义时间范围
  37. CurrentFlow
  38. EndFlow = CurrentFlowInt
  39. '获取结束时接收的流量(字节)
  40. Wscript.Echo "EndFlow: " & EndFlow
  41. Result = EndFlow-BeginFlow
  42. If Result<10240 Then
  43. '10240即10KB,当120000毫秒(120秒=2分钟)(上面的时间范围)内接收流量小于10KB就关闭系统
  44. WScript.Echo "关闭系统."
  45. ObjectWSH.Run"shutdown.exe -s -t 0", 0, TRUE
  46. End If
  47. '计算结果并比较
  48. WScript.Echo "Exit..."
  49. WScript.Sleep 10000
  50. WScript.Quit(0)
  51. End If
  52. Loop
  53. Function CurrentFlow
  54. Set ObjectFlows = ObjectWMI.InstancesOf("Win32_PerfRawData_Tcpip_NetworkInterface")
  55. For Each ObjectFlow In ObjectFlows
  56. strNetName = Split(ObjectFlow.Name, " ", -1, 1)
  57. str2 = strNetName(0) & strNetName(1) & strNetName(2)
  58. If str1 = str2 Then
  59. CurrentFlowInt = ObjectFlow.BytesReceivedPersec
  60. End If
  61. Next
  62. End Function
复制代码
这个代码,属于测试代码,时间间隔设置成2分钟,会陆续弹出相关窗口。

遇到的问题是:

xp sp3系统下,

如果vbs代码先启动,再启动迅雷7的话,测试正常(弹出窗口,可以自动关机)。

如果迅雷7先启动,再运行这个vbs代码,测试无反映(不弹出窗口,不自动关机)。

TOP

顶啊,多谢各位了。

TOP

本帖最后由 ygqiang 于 2011-10-6 20:46 编辑

下面是初步测试vbs代码,可以根据需要,修改时间长度、取消弹出窗口代码

但遇到个小问题,见1楼描述。
  1. '======================================================================
  2. '程序开始------检测迅雷是否运行-----是-----开始网络监视
  3. '       | ↑
  4. '       否 |
  5. '       | |
  6. ' ↑------ 一直监视系统进程-----迅雷运行---
  7. ' |       |
  8. ' ----------- 未运行
  9. '======================================================================
  10. On Error Resume Next
  11. Public CurrentFlowInt, ProFlag
  12. ConnectionID = "本地连接"
  13. Set ObjectNetwork = CreateObject("Wscript.Network")
  14. strComputer = ObjectNetwork.ComputerName
  15. '获取计算机名,必须用字符串,不能用.代替
  16. Set ObjectWSH = Wscript.createObject("Wscript.shell")
  17. Set ObjWMIService = GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")
  18. Set NetCards = ObjWMIService.ExecQuery("Select * from Win32_NetworkAdapter WHERE NetConnectionID='" & ConnectionID & "'")
  19. If NetCards.count<>0 Then
  20. For Each NetCard In NetCards
  21. WScript.Echo "Name: " & NetCard.Name & "        MACAddress: " & NetCard.MACAddress
  22. NetCardName = NetCard.Name
  23. strNet = Split(NetCard.Name, " ", -1, 1)
  24. str1 = strNet(0) & strNet(1) & strNet(2)
  25. Next
  26. Else
  27. Wscript.Echo "网卡不存在."
  28. WScript.Quit(0)
  29. End If
  30. '获取用于上网的网卡信息
  31. Set CheckProcess = ObjWMIService.ExecQuery("Select * from Win32_Process WHERE Name='Thunder.exe'")
  32. If CheckProcess.count<>0 Then
  33. ProFlag = 0
  34. Else
  35. ProFlag = 1
  36. End If
  37. Set colMonitoredProcesses = objWMIService.ExecNotificationQuery("select * from __instancecreationevent " & " within 1 where TargetInstance isa 'Win32_Process'")
  38. i = 0
  39. Do While i = 0
  40.     Set CheckProcess = ObjWMIService.ExecQuery("Select * from Win32_Process WHERE Name='Thunder.exe'")
  41. If CheckProcess.count<>0 Then
  42. Wscript.Echo "迅雷已运行."
  43. '监视网络
  44. CurrentFlow
  45. BeginFlow = CurrentFlowInt
  46. '获取开始时接收的流量(字节)
  47. Wscript.Echo "BeginFlow: " & BeginFlow
  48. WScript.Sleep 120000
  49. '定义时间范围
  50. Else
  51. Wscript.Echo "迅雷未运行."
  52. Set objLatestProcess = colMonitoredProcesses.NextEvent
  53. '监视迅雷
  54.     If objLatestProcess.TargetInstance.Name = "Thunder.exe" Then
  55. Wscript.Echo "迅雷已运行."
  56. CurrentFlow
  57. BeginFlow = CurrentFlowInt
  58. '获取开始时接收的流量(字节)
  59. Wscript.Echo "BeginFlow: " & BeginFlow
  60. WScript.Sleep 120000
  61. '定义时间范围
  62. End If
  63. End If
  64. CurrentFlow
  65. EndFlow = CurrentFlowInt
  66. '获取结束时接收的流量(字节)
  67. Wscript.Echo "EndFlow: " & EndFlow
  68. Result = EndFlow - BeginFlow
  69. If Result<20480 Then
  70. '10240即10KB,当120000毫秒(120秒=2分钟)(上面的时间范围)内接收流量小于20KB就关闭系统
  71. WScript.Echo "关闭系统."
  72. ObjectWSH.Run"shutdown.exe -s -t 0", 0, TRUE
  73. End If
  74. '计算结果并比较
  75. WScript.Echo "Exit ..."
  76. WScript.Quit(0)
  77. Loop
  78. Function CurrentFlow
  79. Set ObjectFlows = objWMIService.InstancesOf("Win32_PerfRawData_Tcpip_NetworkInterface")
  80. For Each ObjectFlow In ObjectFlows
  81. strNetName = Split(ObjectFlow.Name, " ", -1, 1)
  82. str2 = strNetName(0) & strNetName(1) & strNetName(2)
  83. If str1 = str2 Then
  84. CurrentFlowInt = ObjectFlow.BytesReceivedPersec
  85. End If
  86. Next
  87. End Function
复制代码
1

评分人数

    • CrLf: 乐于助人技术 + 1

TOP

有人说:CurrentFlow函数没调用成功  流量统计有问题

xp系统下测试的。

TOP

也有人说:是xp系统本身的问题。

TOP

本帖最后由 ygqiang 于 2011-10-8 11:05 编辑

基本确定是xp系统的问题。
  1. Set ObjectFlows = objWMIService.InstancesOf("Win32_PerfRawData_Tcpip_NetworkInterface")
复制代码
这个vbs代码,在3个ghost xp系统下运行测试。
其中2个xp系统下可以运行。另1个xp系统不能运行。

是哪里出现问题了?

不能运行的xp系统,是不是服务没有开启或者别的原因?


不能运行的xp系统,是不是服务没有开启或者别的原因?



刚刚发现,33楼的代码,在这3个ghost xp版本上,运行都不能达到预期效果。

即使没有开迅雷,还会出现关机的窗口。

TOP

返回列表