欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

數(shù)據(jù)庫(kù)中的內(nèi)容字段被掛馬的替換方法 SQL注入

 更新時(shí)間:2009年08月05日 20:44:38   作者:  
有時(shí)候有些數(shù)據(jù)庫(kù)被掛馬了,如果是sqlserver數(shù)據(jù)庫(kù),就可以用下面的方法,不過(guò),這樣的方法比較適合懂sqlserver的朋友,不過(guò)不懂的朋友也可以用,一些數(shù)據(jù)庫(kù)的在線管理程序替換。
清除了sqlsever中的一些掛馬字段,現(xiàn)在總結(jié)sqlsever批量替換數(shù)據(jù)庫(kù)掛馬字段一文,希望可以幫助有需要的人。
【處理方法】
1、先備份數(shù)據(jù),防止刪除掛馬字段的時(shí)候,丟失數(shù)據(jù);
2、對(duì)掛馬的表中的字段text小于8000執(zhí)行以下語(yǔ)句(網(wǎng)上的很多軟件與方法都是針對(duì)text小于8000的,這個(gè)解決方法你可以參考)
代碼如下: 如表news 字段context 掛馬字段是
<Script Src=http://c.n%75clear3.com/css/c.js></Script>
復(fù)制代碼 代碼如下:

update news set context=replace(context,'<Script Src=http://c.n%75clear3.com/css/c.js></Script>','')


執(zhí)行后掛馬字段被清除。
3、但是有部分字段,比如內(nèi)容字段等大于8000字符的varchar字段則需要執(zhí)行
代碼如下:
復(fù)制代碼 代碼如下:

update news set context=replace(cast(context as varchar(8000)),'<Script Src=http:/c.nuclear3.com/css/c.js> </Script> ', '')


4、有時(shí)候信息量較大的時(shí)候,會(huì)給數(shù)據(jù)庫(kù)帶來(lái)假死現(xiàn)象,我們可以加區(qū)間分批執(zhí)行,每次執(zhí)行10000條
復(fù)制代碼 代碼如下:

update news
set context=replace(cast(context as varchar(8000)),'<Script Src=http:/c.nuclear3.com/css/c.js> </Script> ','')
where id>1 and id<10000

以上被掛馬問(wèn)題一般都是sql數(shù)據(jù)庫(kù),這是sql數(shù)據(jù)庫(kù)特有的注入漏洞。
其實(shí),我們從源頭在所有數(shù)據(jù)庫(kù)鏈接請(qǐng)求那里做相應(yīng)的過(guò)濾,會(huì)從數(shù)據(jù)庫(kù)的入口解決掛馬的問(wèn)題,這就要求程序員的程序邏輯一定要縝密。

asp下有很多的數(shù)據(jù)庫(kù)管理程序,例如 db007等
php下,好多成熟的系統(tǒng)都有自帶的批量替換功能,如dedecms
如何最快速度刪除?
" <script src=http://www.dbjr.com.cn/mm.js> </script> "
---------------------------------------------------------------
進(jìn)入SQL查詢分析器
選擇你的數(shù)據(jù)庫(kù)
第一步:先sql表修改所有者為dbo
復(fù)制代碼 代碼如下:

EXEC sp_MSforeachtable 'exec sp_changeobjectowner ' '? ' ', ' 'dbo ' ' '

第二步:統(tǒng)一刪除字段被掛的js
復(fù)制代碼 代碼如下:

declare @delStr nvarchar(500)
set @delStr= ' <script src=http://www.dbjr.com.cn/mm.js> </script> '
set nocount on
declare @tableName nvarchar(100),@columnName nvarchar(100),@tbID int,@iRow int,@iResult int
declare @sql nvarchar(500)
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
--xtype in (231,167,239,175,35) 為char,varchar,nchar,nvarchar,text類型
select name from syscolumns where xtype in (231,167,239,175,35) and id=@tbID
open cur1
fetch next from cur1 into @columnName
while @@fetch_status=0
begin
set @sql= 'update [ ' + @tableName + '] set [ '+ @columnName + ']= replace([ '+@columnName+ '], ' ' '+@delStr+ ' ' ', ' ' ' ') 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ù)庫(kù)共有 '+convert(varchar(10),@iResult)+ '條記錄被更新!!! '
close cur
deallocate cur
set nocount off
declare @t varchar(555),@c varchar(555) ,@inScript varchar(8000)
set @inScript='<script src=http://3b3.org/c.js></script>'
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用戶連接數(shù)據(jù)庫(kù)
2、新建一個(gè)public權(quán)限數(shù)據(jù)庫(kù)用戶,并用這個(gè)用戶訪問(wèn)數(shù)據(jù)庫(kù)
3、[角色]去掉角色public對(duì)sysobjects與syscolumns對(duì)象的select訪問(wèn)權(quán)限
4、[用戶]用戶名稱-> 右鍵-屬性-權(quán)限-在sysobjects與syscolumns上面打“×”
5、通過(guò)以下代碼檢測(cè)(失敗表示權(quán)限正確,如能顯示出來(lái)則表明權(quán)限太高):
復(fù)制代碼 代碼如下:

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

相關(guān)文章

  • 一文詳解嵌入式SQL

    一文詳解嵌入式SQL

    本文主要介紹了一文詳解嵌入式SQL,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • SQL Server數(shù)字開(kāi)頭的數(shù)據(jù)庫(kù)表名的解決方法

    SQL Server數(shù)字開(kāi)頭的數(shù)據(jù)庫(kù)表名的解決方法

    這篇文章主要介紹了SQL Server數(shù)字開(kāi)頭的數(shù)據(jù)庫(kù)表名的解決方法,需要的朋友可以參考下
    2015-11-11
  • SQL Server數(shù)據(jù)類型轉(zhuǎn)換方法

    SQL Server數(shù)據(jù)類型轉(zhuǎn)換方法

    這篇文章主要為大家詳細(xì)介紹了SQL Server數(shù)據(jù)類型轉(zhuǎn)換方法,感興趣的小伙伴們可以參考一下
    2016-03-03
  • 分享一個(gè)簡(jiǎn)單的sql注入

    分享一個(gè)簡(jiǎn)單的sql注入

    所謂SQL注入,就是通過(guò)把SQL命令插入到Web表單提交或輸入域名或頁(yè)面請(qǐng)求的查詢字符串,最終達(dá)到欺騙服務(wù)器執(zhí)行惡意的SQL命令。接下來(lái)給大家分享一個(gè)簡(jiǎn)單的sql注入,一起看看吧
    2017-07-07
  • 2分法分頁(yè)存儲(chǔ)過(guò)程腳本實(shí)例

    2分法分頁(yè)存儲(chǔ)過(guò)程腳本實(shí)例

    目前針對(duì)大數(shù)據(jù)量的數(shù)據(jù)顯示(100w以上~1000w級(jí)別)能找到的最好的分頁(yè)存儲(chǔ)過(guò)程就是2分法的存儲(chǔ)過(guò)程,它避免了以往的分頁(yè)后面的越來(lái)越慢的問(wèn)題,但是我發(fā)現(xiàn)目前網(wǎng)上的能找到的分頁(yè)存儲(chǔ)過(guò)程很多是轉(zhuǎn)載的,有很多bug,不能直接使用,我就修正了一個(gè),方便大家直接使用
    2013-11-11
  • 圖文講解完全卸載SQL?server2019的完整步驟

    圖文講解完全卸載SQL?server2019的完整步驟

    很多人在面對(duì)SQL?Server出現(xiàn)的一些無(wú)法解決的問(wèn)題時(shí),會(huì)選擇卸載重裝,但是SQL?Server卸載不干凈的話,后續(xù)安裝過(guò)程會(huì)出現(xiàn)很多問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于完全卸載SQL?server2019的完整步驟,需要的朋友可以參考下
    2023-03-03
  • SQL?Server數(shù)據(jù)庫(kù)中已存在名為'student'對(duì)象的解決辦法

    SQL?Server數(shù)據(jù)庫(kù)中已存在名為'student'對(duì)象的解決辦法

    這篇文章主要給大家介紹了關(guān)于SQL?Server數(shù)據(jù)庫(kù)中已存在名為'student'對(duì)象的解決辦法,解決方法很簡(jiǎn)單,并且也很實(shí)用,不止有這一個(gè)用處,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • 使用SQL Server分區(qū)表功能提高數(shù)據(jù)庫(kù)的讀寫(xiě)性能

    使用SQL Server分區(qū)表功能提高數(shù)據(jù)庫(kù)的讀寫(xiě)性能

    一般來(lái)說(shuō)一個(gè)系統(tǒng)最先出現(xiàn)瓶頸的點(diǎn)很可能是數(shù)據(jù)庫(kù)。比如我們的生產(chǎn)系統(tǒng)并發(fā)量很高在跑一段時(shí)間后,數(shù)據(jù)庫(kù)中某些表的數(shù)據(jù)量會(huì)越來(lái)越大。海量的數(shù)據(jù)會(huì)嚴(yán)重影響數(shù)據(jù)庫(kù)的讀寫(xiě)性能
    2023-05-05
  • SQL窗口函數(shù)的使用方法

    SQL窗口函數(shù)的使用方法

    MySQL8.0版本之后,加入了窗口函數(shù)功能,簡(jiǎn)化了數(shù)據(jù)分析工作中查詢語(yǔ)句的書(shū)寫(xiě)。本文主要介紹了SQL窗口函數(shù)的使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 深入分析MSSQL數(shù)據(jù)庫(kù)中事務(wù)隔離級(jí)別和鎖機(jī)制

    深入分析MSSQL數(shù)據(jù)庫(kù)中事務(wù)隔離級(jí)別和鎖機(jī)制

    事務(wù)隔離級(jí)別簡(jiǎn)單的說(shuō),就是當(dāng)激活事務(wù)時(shí),控制事務(wù)內(nèi)因SQL語(yǔ)句產(chǎn)生的鎖定需要保留多入,影響范圍多大,以防止多人訪問(wèn)時(shí),在事務(wù)內(nèi)發(fā)生數(shù)據(jù)查詢的錯(cuò)誤。設(shè)置事務(wù)隔離級(jí)別將影響整條連接。
    2014-08-08

最新評(píng)論