- 帖子
- 14935
- 积分
- 46142
- 技术
- 857
- 捐助
- 745
- 注册时间
- 2008-6-9
|
先说题外话,不喜或不同观点者勿怪:
1、说的是DOS,CMD可以不用看
2、在CN-DOS论坛上找到一个有关BAT加密的高楼大厦,一口气从1楼爬到350楼,试验一下,结果是:
大失所望,这些所谓的加密可说是自欺欺人,最简单的破解方法是先用RAR压缩,再用RAR查看,加密一目了然,所以奉劝各位,别再在BAT加密上浪费时间和精力了。
3、非要bat加密,只有bat2com。有人说了,bat2com将bat转换为COM或EXE的成功率很低,的确如此,我以前试过好几回,很少有成功的,那我还来这说什么?
稍别勿噪,我可以负责任的告诉你,bat2com真的很好很实用。
言归正传
一、转换不成功的原因分析
1、毫无疑问,bat2com肯定不是万能的,有一定的局限性,也有几个BUG,这是转换不成功的原因之一
2、你可能不太了解bat2com的处理规范,或你的BAT程序没有按bat2com的规范来编写,或者超出了bat2com的处理能力范围,这是转换不成功的最主要原因。
bat2com转换不成功的道理,与大多数CMD在dos下运行不成功的道理是一样的,只要你按dos规范来写CMD,那CMD就可以在dos下成功运行,废话)
问题关键:是等bat2com的作者来修改、升级他的程序以适应你的BAT,还是修改你的BAT,让你的BAT适应bat2com的要求,成功还是失败,这是个问题。
二、bat2com的转换规范(以目前我手上的bat2com V1.5为例)
bat2com是按照bat的规范来处理的,对bat有很好的支持:
1、直接支持dos内部命令、外部命令,能带参数
2、直接支持IF、goto命令,支持GOTO的标号
3、忽略REM注解行
4、for命令是唯一的,直接以BAT方式执行。
5、每一行只执行唯一的一个命令,每个命令必须在一行中完成,即基本不支持|与>命令。
1-4 条与一般的bat要求是一致的,唯有第五条,是与常规bat的重大区别!!
三、基本要求,首先注意两点:
1、goto标号(:开头)不能重复,这比bat的要求严格。
2、保证你的BAT能在dos中以bat方式正确执行,这是前提条件,别以为这是废话。
四、解读bat2com与BAT的重要区别
(一)、最主要的一条:每一行只执行唯一的一个命令,每个命令必须在一行中完成,即基本不支持|与>命令 1、每行只能执行一个命令,就是说不允许有"|"( 管道),
2、除了echo 或者 dir之外,其他情况不允许再有转向命令(>,>>)
如:type a.txt | find "abc" -->非法(不能有|)
再如:find "abc' a.txt >b.txt --->非法(不能有>)
再再如:外部命令dspt.exe 0 /l >d.txt --->非法(不能有>)
再再再如: for %%i in (%a%) do echo %%i >>c.txt ->非法(不能有>,>>)
再再再再如:if %a%==1 if %b%==2 set c=3 -->非法(不能连续执行)
我敢打赌,所谓BAT2com成功率低,绝大数的bat就因为这一条!
如果你的BAT中已经没有了上述类似文本,我相信,你的bat2com已经成功了90%。
怎么样,有点眉目了吧,别急,还没完呢
(二)call 命令不会返回参数
举例如下:
set a=123
call b.bat ------>b.bat中的命令为:set a=abc
echo %a%
对于bat方式,执行上述命令后,echo 的结果是:abc
这是我们最常用的bat命令调用,也就是说,bat传送变量。
但是,对于bat2com,它执行的结果是:123 ------》 没错,还是123 !!
真的没错,这不是Bat2com的Bug,也不是bat的bug,这是标准的com、exe执行方式,
其实,这个应该很好理解,这与一个exe程序不能直接向另一个exe程序传递参数一样。
例如,如果你的bat中用到wbat.com,其中有个w.bat,若bat2com后,w.bat所传递的参数将无效。
如果你知道什么是全局变量、局部变量,那你该一点就通,如果还不了解,可以看看有关方面的书,也可做以下试验:
执行以下命令,你就会明白:
set a=123
echo %a% ------->结果是:123,没错
command /k
set a=abc
echo %a% ------->显示:abc,也没错
exit
echo %a% -------》结果是什么,是123或是abc? 自己做吧
就是全局变量与局部变量的简单显示,当然,如果你的bat根本就没有call命令,那你是不会在意的。
(三)极个别第三方软件bat2com后,运行不正常,人无完人,别太苛求,试验后确定吧,实在不行就Call。
五、bat2com有两个严重的bug,必须避开它:
1、变量名,如bat中有:
set a=1
set ab=2
set abc=3
这三条命令在bat中执行正确,但BAT2com中会认为是一样的,会出错,这是一个BUG,只要避开它就可了:即变量名不要有完全重合。
2、echo set a=c:>a.txt
echo dir %%a%%>>a.txt
这两条命令在bat中执行正确,但在bat2com中会在"c:"及%a%后面多出几个空格,
set a=c:变成了set a=c: ,会出现错误,这也是一个BUG,普通的文本输出没有问题,如有必要,也要避开它。
六、解决的办法推荐
如果你按照上述要求重新修改你的BAT程序,bat2com成功,将近在眼前!
1、通过call 调用子程序BAT,执行|或>命令
你肯定会说,我的程序一定要有如:type a.txt | find "abc" 或 dspt.exe 0 /l >d.txt 或echo set a=c:>a.txt
很简单啊,将它做子程序bat,通过call调用,记住,子程序不能再bat2com!
2、子程序的参数不能通过set命令传递给bat2com,可能过文件方式,如
echo %你的参数% >a.txt
然后再在主程序读取a.txt的内容作为参数即可,这也是exe文件之间传递参数的标准方式。
七、隆重推荐:strings.com
有关trings.com的下载及介绍,论坛上很多,请自行搜索。
我只想说,strings是dos-bat的最佳搭档,有了strings,几乎可以完成bat所想完成的任何操作,如果没有strings,我肯定不会写这编文章的。
如echo echo 123>b.txt >a.bat,或echo type a.txt | find "abc" >a.bat
想在bat成功执行上述,得到正确的a.bat,是很难的(通过prompt变通,可以,但比较复杂),在bat2com中是绝对不可能的,但是,strings却能轻易做到!
strings的write命令,可以完善代替echo,而且对于>|等echo不认的符号,解决的非常好,如:
strings write a.bat,strings vhao=char 62 --》 set vhao=>
strings write a.bat, echo 123%%vhao%%b.txt --》 echo echo 123>b.txt >a.bat
其中Vhao为>,可以任意定义为|等,运行a.bat即可得b.txt
处理call返回的参数,变量运算、分析处理等等,strings都能轻松做到。
strings功能还很多,所以我推荐。
八、补充:
1、建议在dos环境中进行bat2com
2、任何bat2com之前,必须确保bat文件能正确运行
3、com文件不得大于64KB!
4、bat2com能正确执行后,再执行com2exe,将文件转换为exe。
九、附言:
为了数据安全,我一直想找个bat加密或2com的方法,如前所述,几经失望,后来想自己弄个for dos程序,但有近1n年没玩c++了,头痛,后来找到bat2com的原程序,仔细一看,正中下怀,逐步明白以前转换不成功的原因所在,经过n次测试,终于成功bat2com。
如果bat2com的作者能看到此文,最好能修正BUG、升级bat2com,或者等我哪天有空了,重操C++,邦他完善一下。
衷心感谢bat2com的作者(不能确定是否董占山)、strings的作者、strings帮助中文翻译(cn-dos的insert)、以及中国DOS联盟的热心的DOS高手!
好了,这是本人经过N次测试得出的经验,难免错漏之处,欢迎补充、完善、指正。
欢迎交流,歌理 QQ107660899 2008.12.02
附件是:bat2com\com2exe\strings
http://www.cn-dos.net/forum/atta ... 3880&download=1 |
|