一个把任何文件转成批处理的vbs脚本Any2Bat.vbs_vbs

by zzzevazzz@ph4nt0m.org

用Base64编码数据,好处是压缩了大小(相对bin2str而言),缺点是增加处理时间和脚本复杂度。
由于效率瓶颈是在bat生成vbs这一步,所以总的来说还是合算了。
写文件用ADODB.Recordset,比debug好使多了。
大部分事都是脚本做的,批处理只是用echo来生成脚本而已。
echo版的好处是,全选复制粘贴到cmd shell里就把文件上传了。

复制代码 代码如下:

'Any2Bat.vbs by zzzEVAzzz 
on error resume next 
set arg=wscript.arguments 
if arg.count=0 then wscript.quit 
with CreateObject("ADODB.Stream") 
.type=1:.open:.loadfromfile arg(0):bs=.read:l=.size:.close 
end with 
if err.number<>0 then wscript.quit 
set fso=CreateObject("Scripting.FileSystemObject") 
with fso.opentextfile(arg(0)&".bat",2,true) 
if err.number<>0 then wscript.quit 
.writeline "@echo bs=_>xx.vbs" 
for k=1 to l step 129 
.write "@echo """ 
.write b64b(midb(bs,k,129)) 
.writeline """+_>>xx.vbs" 
next 
.writeline "@echo """":set rs=CreateObject(""ADODB.Recordset"")>>xx.vbs" 
.writeline "@echo set ado=CreateObject(""ADODB.Stream"")>>xx.vbs" 
.writeline "@echo l=len(bs):ss="""":for k=1 to l step 4096:ss=ss+ub64(mid(bs,k,4096)):next:l=len(ss)>>xx.vbs" 
.writeline "@echo rs.fields.append ""b"",205,l/2:rs.open:rs.addnew:rs(""b"")=ss+chrb(0):rs.update>>xx.vbs" 
.writeline "@echo ado.mode=3:ado.type=1:ado.open:ado.write rs(""b"").getchunk(l/2)>>xx.vbs" 
.writeline "@echo ado.savetofile """+fso.getfilename(arg(0))+""",2:ado.close>>xx.vbs" 
.writeline "@echo function ub64(s):dim t(4),b(3):ub64="""":n=len(s):r=2 >>xx.vbs" 
.writeline "@echo if n mod 4^<^>0 then exit function:end if:for i=1 to n step 4:for j=0 to 3 >>xx.vbs" 
.writeline "@echo a=asc(mid(s,i+j,1)):if a=43 then:a=62:else if a=47 then:a=63:else if a^>47 and a^<58 then:_>>xx.vbs" 
.writeline "@echo a=a+4:else if a=61 then:a=0:if r=2 then r=j-2:end if:else if a^>64 and a^<91 then:_>>xx.vbs" 
.writeline "@echo a=a-65:else if a^>96 and a^<123 then:a=a-71:else:exit function:_>>xx.vbs" 
.writeline "@echo end if:end if:end if:end if:end if:end if:t(j)=a:next>>xx.vbs" 
.writeline "@echo b(0)=t(0)+t(1)*64 mod 256:b(1)=t(1)\4+t(2)*16 mod 256:b(2)=t(2)\16+t(3)*4 >>xx.vbs" 
.writeline "@echo for j=0 to r:if b(j)^<16 then ub64=ub64+""0"":end if:ub64=ub64+hex(b(j))>>xx.vbs" 
.writeline "@echo next:next:end function>>xx.vbs&&cscript.exe //nologo xx.vbs&del xx.vbs" 
end with 
const b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" 
function b64b(bin) 
b64b="" 
n=lenb(bin) 
for i=1 to n step 3 
a=ascb(midb(bin,i,1)) 
b64b=b64b+mid(b64,a mod 64+1,1) 
if i<n then 
b=ascb(midb(bin,i+1,1)) 
b64b=b64b+mid(b64,(a\64+b*4)mod 64+1,1) 
if i+1<n then 
c=ascb(midb(bin,i+2,1)) 
b64b=b64b+mid(b64,(b\16+c*16)mod 64+1,1) 
b64b=b64b+mid(b64,c\4+1,1) 
else 
b64b=b64b+mid(b64,b\16+1,1) 
b64b=b64b+"=" 
end if 
else 
b64b=b64b+mid(b64,a\64+1,1) 
b64b=b64b+"==" 
end if 
next 
end function 

用法很简单,就一个参数——要转换的文件全路径。
也可以直接拖放文件到这个vbs的图标上。

时间: 2024-08-02 09:50:37

一个把任何文件转成批处理的vbs脚本Any2Bat.vbs_vbs的相关文章

一个扩展时间段的dir命令的vbs脚本_vbs

set Arg=Wscript.Arguments If Arg.Count=0 then Wscript.echo chr(9)&chr(9)&space(4)&"Xdir v0.1" Wscript.echo "" Wscript.echo chr(9)&"cscript dir.vbs path time1 time2 ext" Wscript.echo chr(9)&"cscript di

VBS脚本病毒原理分析与防范_vbs

网络的流行,让我们的世界变得更加美好,但它也有让人不愉快的时候.当您收到一封主题为"I Love You"的邮件,用兴奋得几乎快发抖的鼠标去点击附件的时候:当您浏览一个信任的网站之后,发现打开每个文件夹的速度非常慢的时候,您是否察觉病毒已经闯进了您的世界呢?2000年5月4日欧美爆发的"爱虫"网络蠕虫病毒.由于通过电子邮件系统传播,爱虫病毒在短短几天内狂袭全球数百万计的电脑.微软.Intel等在内的众多大型企业网络系统瘫痪,全球经济损失达几十亿美元.而去年爆发的新欢

利用计划任务和VBS脚本实现自动WEB共享文件夹里的文件

web|脚本 其实没有题目写得那么复杂,就是用计划任务每隔一段时间调用VBS脚本,刷新生成一个文件列表文件用于WEB服务调用. Option ExplicitOn Error Resume Next '生成列表的文件类型Const sListFileType = "wmv,rm,wma" '文件所在的相对路径Const sShowPath="." '排序类型的常量定义Const iOrderFieldFileName = 0Const iOrderFieldFile

vbs脚本实现批量转换文件编码_vbs

最近需要使用SourceInsight查看分析在Linux系统下开发的项目代码,我们知道Linux系统中文本文件默认编码格式是UTF-8,而Windows中文系统中的默认编码格式是Gb2312.系统内的编码格式有所区别倒无伤大雅,关键的是SourceInsight竟不支持UTF-8,导致项目代码内的中文注释全部乱码! 既然SourceInsight不支持UTF-8编码的文件,那我们就得想办法将UTF-8的代码文件转化为GB2312编码的.首先想到的是到网上搜一下"批量编码转换工具",结

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

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

从一个VBS脚本学习一点点东西_vbs

不知道是最近还是以前,反正就是这几天经常在网上看到一个刷QQ群的VBS代码. 复制代码 代码如下: Set WshShell= WScript.createObject("WScript.Shell") WshShell.AppActivate "群 - Powers成员交流" for i=1 to 10 '要发的次数 WScript.Sleep 500 '发送消息的时间间隔 WshShell.SendKeys "^v" '要发的内容 WshSh

C或C++如何捕获一个指定盘内文件的打开操作?

问题描述 C或C++如何捕获一个指定盘内文件的打开操作? 有一个安全区盘,登陆相关软件的时候这个盘才会显示出来,才能进行里面的文件操作,现在我已经登陆了这个软件,那么怎样才能捕获到这个安全区内文件的打开操作呢? 解决方案 不知道你说的安全盘怎么实现的,如果就是文件系统,就直接打开读取就可以了.如果是shell namespace扩展,这个是没办法直接调用的,要看有没有编程接口了. 解决方案二: 该怎么直接打开读取呢?希望你说具体点,我就是个大菜鸟,嘿嘿

linux下怎么写一个自动创建文件夹和文件的脚本?

问题描述 linux下怎么写一个自动创建文件夹和文件的脚本? linux下怎么写一个自动创建文件夹和文件的脚本?就是说我给一个绝对路径,程序会自动帮我创建在路径中没有的文件夹和文件. 解决方案 http://blog.csdn.net/hellochenlian/article/details/37566269 -p, --parents 可以是一个路径名称.此时若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录; 解决方案二: mkdir 加上

图片压缩-如何判断一个JPEG2000的文件中的每一个packet?

问题描述 如何判断一个JPEG2000的文件中的每一个packet? 最近在研究JPEG2000的图像格式,我发现一个问题.现在到这里来问问一下大神. 从理论上将,JPEG2000的image只要一些最基本的数据不丢失的话,其它部分的数据丢失的话,是不会影响太大的(除了resolution和qunlity的). 但是现在我想知道的问题是,我手头里有一个JPEG2000的格式的文件,我该如何知道它的哪一部分的数据是可以丢掉的啊? 解决方案 http://wenku.baidu.com/link?u