也想出现在这里? 联系我们

通过SQL注入得到WebShell的原理及步骤

作者 : 小编 本文共2628个字,预计阅读时间需要7分钟 发布时间: 2021-06-2 共3.13K人阅读
也想出现在这里? 联系我们

一.通过SQL注入得到WEBSHELL的原理:

N.E.V.E.R的方法:利用数据库备份得到WEBSHELL。创建一个表,在表中建一个字段用来保存木马数据。然后利用MSSQL导出文件的办法把整个数据导出来,最后再删除新建的表。

分析: N.E.V.E.R利用了MSSQL的备份数据库功能。把数据导出来,设想数据库中有<%%>之类的ASP标实符,导出文件,文件名以.ASP的形式保存。然后文件又保存在WEB的路径下。那么这个导出的ASP文件是不是要去解释<%%> 之内的语句呢?如果数据库中有的表中有<%%>标实符,并且这之中有错误,那么我们导出来生成的ASP文件也会有误。不过,这种机会也不太大。

再来看看CZY的方法吧。

CZY的方法:前面的和N.E.V.E.R的方法基本上差不多。只是后面用到了扩展存储过程——sp_makewebtask。这个扩展存储过程的作用就是:可以把MSSQL数据库中的某个表中的记录导出来,以文件的方法保存起来。这种方法就不会出现什么问题原因在于:我们只去读表中的某个字段中的值。把字段的信息导出来生成文件。这个字段中的值都是我们刚加上的。自己在加入数据的时候,先调试一下,没有问题在加入进去,导出来就当然没有问题了。

以上两位的方法,我都手工测试过。利用SQL注入漏洞,建表,向表中加数据,然后再导出数据,再删除表。都是利用的SQL语句。这里我就不多说了,大家可以看本期的文章。

二.利用DELPHI去实现功能的前言

原理都分析过了。我们怎么利用DELPHI来实现他们的手工操作呢?其实方法是非常简单的。DELPHI提供了一个NMHTTP控件。我们利用这个控件就可以向某个特定的URL提交参数。然后实现我们的自动注射功能。我马上要为大家讲解的这个程序,有一个特点。也可以说成是一个缺陷吧。程序不去自动猜解WEB的绝对路径。程序不去判断当前连接SQL数据库的当前账号的权限。我为什么要这么做?因为得到这两者用SQL注入是非常难得到的。所以,我们程序发送命令就不会考虑太多。成不成功你执行完自己去看看生成没有就OK了。

三.如何利用DELPHI得到WEBSHELL。

程序中用到的值。我们这里来看看有哪些:URL路径,远程WEB绝对路径(通过其他方法得到,你一定有办法的) 采用什么方法去得到WEBSHELL(也就是两位的方法,你选哪一种)。我们同时要求点击一个按纽开始执行命令,和点击一个按纽来终止命今。最后就是新建的表的名称,以及表的字段名称,再次就是字段的类型。前面的我们在程序中放上输入,选择之类的控件就行了。后面的我们设一个选项按纽点按纽弹出相应设置。再把这些相应的设置用一个RECORD来保存。

首先,我们在DIT控件。名称分别是:UrlET //URL路径的输入框、ShellPathET //远程木马的位置、CustomBdoorET//自定义木马的位置。再放两个RadioButton用来选择采用什么方式获取WEBSHELL。CAPTION分别取名为: BackUP DataBase 和 WEB作业。然后再放三个SpeedButtion按纽。名称分别是:设置,开始,停止, 最后再放一个MEMO控件。来显示当前添加的信息。到此界面上的工作就做完了。界面如图:

现在来写程序了。

我们首先定义一个RECORD。

如下:

Type

SetOption = Record

TableName : String; //用来保存要创建的表名.

FieldName : String; //用来保存要创建的字段名.

FiledType : String; //用来保存创建的字段名类型.

End;

FiledType字段类型的值是以下类型的一种:

Bigint binary bit char datetime decimal float image int money nchar ntext numeric nvarchar real smalldatetime smallint

Smallmoney sql_variant text timestamp tinyint uniqueidentifier varbinary varchar 这些都是MSSQL字段类型值.

再定义一个全局变量:

Var

ISStop : Boolean; //用来判断用户是否按下了停止按纽.

好了。在表单创建的过程中,我们为RECORD记录输入默认值.

代码如下:

procedure TMainForm.FormCreate(Sender: TObject);

begin

sOption.TableName :=’cyfd’

sOption.FieldName :=’gmemo’

sOption.FiledType :=’text’

end;

现在我们添加开始执行命令的代码。

先定义BDoorList 为TstringList。主要目的就是把木马的内容加进来.

创建两个变量来保存urlET.和ShellPathET的值.方便程序简化调用.

在程序开始执行前,我们得先检查一下用户的输入

定义一个Checkinput函数.

如下:

Function CheckInput : Boolean;

Begin

Result := False;

if Trim(urlet.Text) = ’’ then

Begin

Application.MessageBox(’请输入URL地址!’,’提示’,mb_ok mb_iconinformation);

Exit;

End;

if Trim(ShellPathET.Text) = ’’ then

Begin

Application.MessageBox(’请输入文件保存地址!’,’提示’,mb_ok mb_iconinformation);

Exit;

End;

IF DefBDoor.Checked then

Begin

if Not FileExists(extractfilepath(Application.ExeName) ’默认木马.txt’) then

Begin

Application.MessageBox(’没有找到 [默认木马.txt] 文件!’,’提示’,mb_ok mb_iconinformation);

Exit;

End;

End

Else

if Not FileExists(CustomBdoorET.Text) then

Begin

Application.MessageBox(’没有找到所选的木马文件!’,’提示’,mb_ok mb_iconinformation);

Exit;

End;

Result := True;

End;

1. 本站所提供的源码模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: rayer@88.com),我们会及时删除,给您带来的不便,我们深表歉意!
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » 通过SQL注入得到WebShell的原理及步骤

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
织梦模板使用说明
你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html

发表评论

Copyright 2015-2020 版权所有 资源分享吧 Rights Reserved. 蜀ICP备14022927号-1
开通VIP 享更多特权,建议使用QQ登录