手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>网站运营>建站经验>列表

让您见识一下SQL Server口令的脆弱性

来源:互联网 作者:west263.com 时间:2008-04-16
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!
CryptAcquireContextW(&hProv,NULL, L("Microsoft Base Cryptographic Provider v1.0"),1,0xf0000000); CryptCreateHash(hProv,0x8004,NULL,NULL,&hhash); CryptCreateHash(hProv,0x8004,NULL,NULL,&hHash); 005F9DFE: CryptHashData(hhash,passwdbuf,0x12,NULL);

passwdbuf是小写的passwd缓冲区,然后附加一个KEY,如上例子就是对:

{'1','2'3'4'5'6',0x17,0x51,0x85,0x7F}

这样的一个字串进行HASH加密:

CryptHashData(hHash,PASSWDBUF,0x12,NULL)

;PASSWDBUF是大写的passwd缓冲区,然后附加一个KEY 005F9E3E:

CryptGetHashParam(hhash,2,&passwdout,&outlen,0);

取出passwdbuf是小写的passwd的加密值:

CryptGetHashParam(hHash,2,&PASSWDOUT,&OUTLEN,0);

取出passwdbuf是大写的passwd的加密值这两个相加就是真正的数据库中的PASSWORD加密字段。

为什么说以上方法是脆弱的呢?其实其真正的加密长度生成只有20个字节。

小写口令的HASH1 大写口令的HASH1拼接的40位HASH值的安全度还不如一个直接20位的HASH值来得安全。因为大家都知道这两个值的因果关系,提供给了解密者更多的信息。如因为其算法相同,假如HASH1=HASH2,就能够判断口令肯定是未使用字母,只使用了数字和符号的口令,如上取出的123456口令的HASH,两个HASH完全相等。就是使用了字母,其知道补充的KEY,算法,两个加密字串的关系,其解应该也是大大的简化了。


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!