最近一直在弄网络编程,所以写了个http服务器,也可以说是个b/s木马吧,呵呵,因为实现了一些木马的功能。
默认端口为8000,你可以直接在路径后跟命令,比如http://127.0.0.1:8000/dir
便会回显dir执行的命令信息,http://127.0.0.1:8000/down 1.rar
便会下载1.rar文件,如果是ie,则要把空格写成%20,ff则会自动转换。
我是用多线程来监听客户端连接的,所以可以同时响应多个用户的连接。
在试验中发现ff会在你请求后一直保持连接,而ie则会在你请求得到结果后自动断开,在你下一次请求时重连。所以我在线程函数里便执行了一次接受发送操作,然后断开,该线程返回结束。
关于结果的读取,我采用了单向管道,cmd进程的输出直接绑定到写管道上,然后程序便可以读取了,在下载文件操作上,我是用byte数组的,将http响应头和文件内容直接写入byte数组中,然后发送即可(不能用char数组,char数组以0作为结尾,这在二进制文件传输中是致命的,二进制文件可不是以0结尾的啊)。
本文有不足之处,还望大家多多指正。