Sql Server 批量替换被插入的木马记录
来源:互联网 发布:浴缸推荐 知乎 编辑:程序博客网 时间:2024/05/16 08:20
最近公司做的一个事业性质网站被黑客攻击了,通过sql注入方式,把木马注入了数据库,整个MSSQL SERVER 的数据都被附加上恶意脚本了,最近找了找 批量替换被插入的木马记录,找到了一条好的语句,用处很大,仅仅使用十几行游标语句,把整个数据库的所有表的恶意木马清除掉了,而且在Google搜索到此记录几率很小,在此专门转载一下!为了以后自己能找得到,也希望后人能得到帮助。
原文如下:
declare @t varchar(555),@c varchar(555) ,@inScript varchar(8000)
set @inScript='恶意代码'
declare table_cursor cursor for select a.name,b.name from sysobjects a,syscolumns b where a.id=b.id and a.xtype='u' and (b.xtype=99 or b.xtype=35 or b.xtype=231 or b.xtype=167)
open table_cursor
fetch next from table_cursor into @t,@c
while(@@fetch_status=0)
begin
exec('update ['+@t+'] set ['+@c+']=replace(cast(['+@c+'] as varchar(8000)),'''+@inScript+''','''')' )
fetch next from table_cursor into @t,@c
end
close table_cursor
deallocate table_cursor;
彻底杜绝SQL注入
1.不要使用sa用户连接数据库
2、新建一个public权限数据库用户,并用这个用户访问数据库
3、[角色]去掉角色public对sysobjects与syscolumns对象的select访问权限
4、[用户]用户名称-> 右键-属性-权限-在sysobjects与syscolumns上面打“×”
5、通过以下代码检测(失败表示权限正确,如能显示出来则表明权限太高):
DECLARE @T varchar(255),
@C varchar(255)
DECLARE Table_Cursor CURSOR FOR
Select a.name,b.name from sysobjects a,syscolumns b
where a.id=b.id and a.xtype= 'u ' and (b.xtype=99 or b.xtype=35 or b.xtype=231 or b.xtype=167)
OPEN Table_Cursor
FETCH NEXT FROM Table_Cursor INTO @T,@C
WHILE(@@FETCH_STATUS=0)
BEGIN print @c
FETCH NEXT FROM Table_Cursor INTO @T,@C
END
CLOSE Table_Cursor
DEALLOCATE Table_Cursor
- Sql Server 批量替换被插入的木马记录
- Sql Server 批量替换被插入的木马记录
- SQL SERVER 批量插入记录
- SQL Server中如何批量插入记录
- SQL Server中如何批量插入记录
- 对于MSSQL数据库被插入的木马可用SQL语句批量删除的方法。
- SQL Server 批量插入数据的方法
- SQL SERVER的批量插入与批量更新
- [SQL Server] 批量插入数据
- sql server insert 批量插入
- 【SQL Server 批量插入数据】
- MSSQL批量替换语句 在SQL SERVER中批量替换字符串的方法
- SQL Server数据库中批量替换数据的方法
- SQL Server数据库中批量替换数据的方法
- 在SQL SERVER中批量替换字符串的方法
- 在SQL SERVER中批量替换字符串的方法
- 在SQL SERVER中批量替换字符串的方法
- SQL Server 批量插入数据的两种方法
- C#获取当前IE的URL
- 图片
- 事务隔离级别示例与分析(二)
- 用javap分析java编译器对string常量表达式的处理和优化
- sqlce 里存取图片
- Sql Server 批量替换被插入的木马记录
- 威博文件管理系统4.0版中,关于webdav的介绍
- ubuntu 安装code blocks全记录
- ABAP 的事件
- document.execCommand()的用法小记
- 我同意条款CheckBox的isChecked属性
- Autonomy 基于语义的搜索
- 编译BaseClasses 编译错误
- redhat虚拟机环境下安装oracle10g--oracle学习1