婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > sql注入數據庫修復的兩種實例方法

sql注入數據庫修復的兩種實例方法

熱門標簽:安陽天音防封電銷卡 陽光創信ai外呼獲客系統助力 云南全自動外呼系統公司 智能外呼系統需要多少錢 競圣地圖標注服務 外呼系統的話術 貴州外呼回撥系統是什么 智能語音車載電話機器人 衛星地圖標注距離

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

復制代碼 代碼如下:

declare @delStr nvarchar(500)   
set @delStr='script src=https://www.jb51.net/js/common.js>/script>' --這里被注入的字段串   
/****************************************/  
/**********以下為操作實體************/   
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 '數據庫教程共有'+convert(varchar(10),@iResult)+'條記錄被更新!!!' 
close cur   
deallocate cur   
set nocount off

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

復制代碼 代碼如下:

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

/**********以下為操作實體************/   
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 '數據庫教程共有'+convert(varchar(10),@iResult)+'條記錄被更新!!!' 
close cur   
deallocate cur   
set nocount off

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

標簽:河源 預約服務 周口 湘潭 營口 欽州 鄂爾多斯 寧夏

巨人網絡通訊聲明:本文標題《sql注入數據庫修復的兩種實例方法》,本文關鍵詞  sql,注入,數據庫,修復,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《sql注入數據庫修復的兩種實例方法》相關的同類信息!
  • 本頁收集關于sql注入數據庫修復的兩種實例方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 资阳市| 孝义市| 上杭县| 翁源县| 嘉黎县| 通山县| 呼图壁县| 邢台市| 温州市| 如皋市| 呼伦贝尔市| 双牌县| 弥渡县| 庄河市| 宜春市| 偃师市| 淳安县| 蒲江县| 噶尔县| 连江县| 镇康县| 麻城市| 稻城县| 吉安市| 滨州市| 徐水县| 合阳县| 都昌县| 南江县| 山西省| 三穗县| 洛宁县| 阿克苏市| 黑山县| 阳新县| 新化县| 六枝特区| 新营市| 上虞市| 朝阳区| 镇巴县|