主頁 > 知識庫 > sql注入數(shù)據(jù)庫修復(fù)的兩種實(shí)例方法

sql注入數(shù)據(jù)庫修復(fù)的兩種實(shí)例方法

熱門標(biāo)簽:安陽天音防封電銷卡 陽光創(chuàng)信ai外呼獲客系統(tǒng)助力 云南全自動外呼系統(tǒng)公司 智能外呼系統(tǒng)需要多少錢 競圣地圖標(biāo)注服務(wù) 外呼系統(tǒng)的話術(shù) 貴州外呼回?fù)芟到y(tǒng)是什么 智能語音車載電話機(jī)器人 衛(wèi)星地圖標(biāo)注距離

1.第一種情況是 需要將指定的 注入字符串全部替換掉(僅替換注入的字符串為空)

復(fù)制代碼 代碼如下:

declare @delStr nvarchar(500)   
set @delStr='script src=https://www.jb51.net/js/common.js>/script>' --這里被注入的字段串   
/****************************************/  
/**********以下為操作實(shí)體************/   
set nocount on 
declare @tableName nvarchar(100),@columnName nvarchar(100),@tbID int,@iRow int,@iResult int  
declare @sql nvarchar(2000)  
set @iResult=0   
declare cur cursor for  
select name,id from sysobjects where xtype='U' 
open cur   
fetch next from cur into @tableName,@tbID  
while @@fetch_status=0   
begin  
declare cur1 cursor for  
select name from syscolumns where xtype in (231,167,239,175, 35, 99) and id=@tbID   
open cur1   
fetch next from cur1 into @columnName   
while @@fetch_status=0   
begin  
set @sql='update [' + @tableName + '] set ['+ @columnName +']= SUBSTRING([' + @columnName + '],' + '1, PATINDEX( ''%' + @delStr + '%'', [' + @columnName + '])-1) + ' + 'SUBSTRING([' + @columnName + '], PATINDEX( ''%' + @delStr + '%'', [' + @columnName + ']) + ' + 'len(''' + @delStr + ''') , datalength([' + @columnName + '])) where ['+@columnName+'] like ''%'+@delStr+'%''' 
exec sp_executesql @sql   
set @iRow=@@rowcount   
set @iResult=@iResult+@iRow   
if @iRow>0   
begin  
print '表:'+@tableName+',列:'+@columnName+'被更新'+convert(varchar(10),@iRow)+'條記錄;'  
end  
fetch next from cur1 into @columnName  

end  
close cur1   
deallocate cur1  
fetch next from cur into @tableName,@tbID   
end  
print '數(shù)據(jù)庫教程共有'+convert(varchar(10),@iResult)+'條記錄被更新!!!' 
close cur   
deallocate cur   
set nocount off

2.第二種是  需要將注入到表中起始位置到最后都刪掉。(此種方法直接找到注入的起始位置,后面的全部刪掉)

復(fù)制代碼 代碼如下:

--恢復(fù)被注入數(shù)據(jù)庫   
--2013-09-26  
declare @delStr nvarchar(500)   
set @delStr='/title>style>.' --被注入的字段串的開始采樣,從此位置后面的數(shù)據(jù)都為注入數(shù)據(jù)  

/**********以下為操作實(shí)體************/   
set nocount on 
declare @tableName nvarchar(100),@columnName nvarchar(100),@tbID int,@iRow int,@iResult int  
declare @sql nvarchar(2000)  
set @iResult=0   
declare cur cursor for  
select name,id from sysobjects where xtype='U' 
open cur   
fetch next from cur into @tableName,@tbID  
while @@fetch_status=0   
begin  
declare cur1 cursor for  
select name from syscolumns where xtype in (231,167,239,175, 35, 99) and id=@tbID   
open cur1   
fetch next from cur1 into @columnName   
while @@fetch_status=0   
begin  
set @sql='update [' + @tableName + '] set ['+ @columnName +']=  
 SUBSTRING([' + @columnName + '],1, PATINDEX( ''%' + @delStr + '%'', [' + @columnName + '])-1)   where ['+@columnName+'] like ''%'+@delStr+'%''' 
exec sp_executesql @sql   
set @iRow=@@rowcount   
set @iResult=@iResult+@iRow   
if @iRow>0   
begin  
print '表:'+@tableName+',列:'+@columnName+'被更新'+convert(varchar(10),@iRow)+'條記錄;'  
end  
fetch next from cur1 into @columnName  

end  
close cur1   
deallocate cur1  
fetch next from cur into @tableName,@tbID   
end  
print '數(shù)據(jù)庫教程共有'+convert(varchar(10),@iResult)+'條記錄被更新!!!' 
close cur   
deallocate cur   
set nocount off

您可能感興趣的文章:
  • 利用SQL注入漏洞登錄后臺的實(shí)現(xiàn)方法
  • 有效防止SQL注入的5種方法總結(jié)
  • 尋找sql注入的網(wǎng)站的方法(必看)

標(biāo)簽:河源 預(yù)約服務(wù) 周口 湘潭 營口 欽州 鄂爾多斯 寧夏

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sql注入數(shù)據(jù)庫修復(fù)的兩種實(shí)例方法》,本文關(guān)鍵詞  sql,注入,數(shù)據(jù)庫,修復(fù),的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sql注入數(shù)據(jù)庫修復(fù)的兩種實(shí)例方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于sql注入數(shù)據(jù)庫修復(fù)的兩種實(shí)例方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章