你的数据库程序会被跟踪吗?什么代码都被别人看光了吗?(SQL SERVER)

博客围绕SQL SERVER数据库展开,介绍了防止程序被他人通过Profiler跟踪的方法。给出了两个解决方案,分别是编写SQLCloseAllTrack过程和使用faq1相关代码,通过执行特定SQL语句停止跟踪器,避免程序信息被暴露。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当你使用的数据库是SQL SERVER时,是不是别人只要打开Profiler,你的程序就感觉赤祼祼了啊,那你想给你的程序穿上防护服吗?今天刚搞定的,

答案(共两个):

procedure SQLCloseAllTrack;
const
  sql = 'declare @TID integer ' +
    'declare Trac Cursor For ' +
    'SELECT Distinct Traceid FROM  :: fn_trace_getinfo(default) ' +

  'open Trac ' +

  'Fetch Next From Trac into @TID ' +

  'while @@fetch_status=0 ' +
    'begin ' +
    '  exec sp_trace_setstatus @TID,0 ' +
    '  exec sp_trace_setstatus @TID,2 ' +

  '  Fetch Next From Trac into @TID ' +
    'end ' +

  'Close Trac ' +
    'deallocate Trac';
begin
  //停止所有SQLSERVER的跟蹤器,以防止程序被別人跟蹤
  ExecSql(sql);
end;



来自:dcsdcs, 时间:2005-4-20 16:54:14, ID:3051360
防止跟踪:with faq1 do
    begin
    Close;
    sql.Clear;
    sql.add('declare @t_count int');
    sql.add('set @t_count=1');
    sql.add('while exists(SELECT * FROM ::::fn_trace_geteventinfo(@t_count))');
    sql.add('begin');
    sql.add('exec sp_trace_setstatus @t_count,0');
    sql.add('set @t_count=@t_count+1');
    sql.add('end');
    try
    execSQL;
    except;
    end;
    close;sql.Clear;
    end;
end;  

防止跟踪:with faq1 do
    begin
    Close;
    sql.Clear;
    sql.add('declare @t_count int');
    sql.add('set @t_count=1');
    sql.add('while exists(SELECT * FROM ::::fn_trace_geteventinfo(@t_count))');
    sql.add('begin');
    sql.add('exec sp_trace_setstatus @t_count,0');
    sql.add('set @t_count=@t_count+1');
    sql.add('end');
    try
    execSQL;
    except;
    end;
    close;sql.Clear;
    end;
end;  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值