婷婷综合国产,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注入數據庫修復的兩種實例方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 雅安市| 色达县| 曲沃县| 金华市| 萨迦县| 包头市| 嘉义县| 盐山县| 马关县| 阿拉善左旗| 兴和县| 灌南县| 陇西县| 嘉义县| 武陟县| 旅游| 兰西县| 襄垣县| 呼和浩特市| 珲春市| 平顶山市| 水富县| 黄陵县| 武胜县| 五华县| 珠海市| 星子县| 辛集市| 安陆市| 永修县| 那曲县| 尚志市| 清远市| 两当县| 七台河市| 疏勒县| 玛多县| 卓尼县| 离岛区| 道孚县| 巨鹿县|