三千论坛
标题:
数据及备份管理
[打印本页]
作者:
异仟年
时间:
2022-9-5 18:06
标题:
数据及备份管理
1
.备份
9 z* j! L( Q/ r0 U, l" d2 X
1
)要经常把重要数据备份到专用的备份服务器,备份完毕后,可将备份服务器与网络隔离。 可采用自动的备份工具进行,要求支持
FTP
方式备份。
2
)使用系统的备份功能对安装好的系统进行阶段性备份。
3
)使用
WonRescue
等工具对注册表进行阶段性备份。
4
)使用
Ghost
对全面配置完毕的系统分区进行映像备份,并存放到隐藏的分区中。
. ]' `( o! Y4 k" \! ~( [: l! Z+ O
! A- H+ J6 w9 j
2
.设置文件共享权限
* `/ f; k) m/ y! Y: }
1
)限制共享权限设置共享文件时,要注意把共享文件的权限从
“everyone”
组改成
“
授权用户
”
,包括打印共享。
2
)关闭默认共享
Win 2000
安装好以后,系统会创建一些隐藏的共享,在
cmd
下可用
net share
命令查看它们。要禁止这些共享。操作方法是:打开
“
管理工具
→
计算机管理
→
共享文件夹
→
共享
”
,在相应的共享文件夹上按右键,点
“
停止共享
”
即可。不当过机器重新启动后,这些共享又会重新开启。
- v: d( V% u7 |% V v1 i$ R
& k4 }) A1 w% Z# G3 U' ? I( D
3.
防止文件名欺骗
. @5 M- u5 g2 n. {3 `
设置以下选项可防止文件名欺骗,如防止以
.txt
或
.exe
为后缀的恶意文件被显示为
.txt
文件,从而使人大意打开该文件
:
双击
“
我的电脑
→
工具
→
文件夹选项
→
查看
”
,选择
“
显示所有文件和文件夹
”
属性设置,去掉
“
隐藏已知文件类型扩展名
”
属性设置。
0 x: O' q5 x$ P9 l
: \6 j' r$ P2 V! K) Y$ w- E
4.Access
数据库的安全概要
4 }2 A( b0 O- m2 p) ?) z, x
1
)新生成的数据库在保证干净的前提下,主动在尾部合并一行
ASP
代码,内容一般可以为重定向,以免别人通过论坛发帖等方式嵌入有害代码后被得到执行;
2
)对
MDB
文件创建一个无效的映射,以便在
IE
中下载时出错;
3
)修改出错页面,建议将出错页面设计为正常被曝库后的内容,但给一个数据库的虚假地址(最好存在相应的虚假数据库文件,比如一个改名后的病毒等);
4
)在防火墙中对
MDB
类型的扩展名进行过滤;
5
)删除或禁用网站的后台数据库备份功能,而用本地安装的专门自动备份程序进行自动增量备份。
6
)
ASP
通用防止注入的程序:功能简单说明:
1.
自动获取页面所有参数,无需手工定义参数名
.2.
提供三种错误处理方式供选择
. (1).
提示信息
. (2).
转向页面
. (3).
提示信息
,
再转向页面
.3.
自定义转向页面
.
使用方法很简单,只需要在
ASP
页面头部插入代码
<!--#Include File="Fy_SqlX.Asp"-->
包含
Fy_SqlX.Asp
就可以了
~~
简单实用
<%Dim Fy_Url,Fy_a,Fy_x,Fy_Cs(),Fy_Cl,Fy_Ts,Fy_Zx''---
定义部份 头
------Fy_Cl = 1 ''
处理方式:
1=
提示信息
,2=
转向页面
,3=
先提示再转向
Fy_Zx = "Error.Asp" ''
出错时转向的页面
On Error Resume NextFy_Url=Request.ServerVariables("QUERY_STRING")Fy_a=split(Fy_Url,"&")redim Fy_Cs(ubound(Fy_a))On Error Resume Nextfor Fy_x=0 to ubound(Fy_a)Fy_Cs(Fy_x) = left(Fy_a(Fy_x),instr(Fy_a(Fy_x),"=")-1)NextFor Fy_x=0 to ubound(Fy_Cs)If Fy_Cs(Fy_x)<>"" ThenIf Instr(LCase(Request(Fy_Cs(Fy_x))),"''")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"and")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"select")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"update")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"chr")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"delete%20from")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),";")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"insert")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"mid")<>0 Or Instr(LCase(Request(Fy_Cs(Fy_x))),"master.")<>0 ThenSelect Case Fy_Cl Case "1"Response.Write "<Script Language=JavaScript>alert(''
出现错误!参数
"&Fy_Cs(Fy_x)&"
的值中包含非法字符串!
\n\n
请不要在参数中出现:
;,and,select,update,insert,delete,chr
等非法字符!
'');window.close();</Script>" Case "2"Response.Write "<Script Language=JavaScript>location.href=''"&Fy_Zx&"''</Script>" Case "3"Response.Write "<Script Language=JavaScript>alert(''
出现错误!参数
"&Fy_Cs(Fy_x)&"
的值中包含非法字符串!
\n\n
请不要在参数中出现:
;,and,select,update,insert,delete,chr
等非法字符!
'');location.href=''"&Fy_Zx&"'';</Script>"End SelectResponse.EndEnd IfEnd IfNext%>
7 I1 L9 \4 V7 x' `
6 y* v8 e& {* ?0 J, j/ ~9 ] N" a
5.MSSQL
注入攻击的防范
7 V! q: K* M+ B- c; ?
在
SQL Server 2000
的安装目录下的
\NSSQL\BINN
文件夹中有一个危险的
DLL
组件,就是
Xplog70.dll
,建议将它改名或者彻底删除!
7 Z1 K5 V% V6 Q. v3 u3 m
+ f, u, v | Q7 U
攻击者可调用
SQL
里的
Master
里的扩展存储过程中的
xp_cmdshell
来执行系统指令。
1
)删除扩展存储过程在控制面板
→
计算机管理
→
Microsoft SQL Server
→
(
Local……
)
→
数据库
→
master
→
扩展存储过程
→
xp_cmdshell
,右击然后删除!也可以使用命令删除:
sp_dropextendedproc ''xp_cmdshell''
接着在系统分区搜索并删除或改名、移除
xplog70.dll
文件防止恶意者恢复上述配置。
2
)删除注册表操作功能删除上述位置下的:
xp_regaddmultistring
(向注册表添加项目)
xp_regdeletekey
(向注册表删除一个项)
xp_regdeletevalue
(向注册表删除一个键值)
xp_regnumvalues
(列举主键下的键值)
xp_regread
(读取一主键下的键值)
xp_regremovemultistring
(从注册表中删除项目)
xp_regwrite
(向注册表中数据)
3
)防范跨库查询每个数据库分别设置一个数据库用户,该用户只能对其拥有的数据库进行查询,禁止其他数据库(包括
4
个系统数据库
Master Model Tempdb Msdb
和两个用户数据库
Pubs t Northwind
)。
* R, E' Y5 V2 C1 i
7 `0 H- _# ~5 `! `, O- ~
如果网站使用了别人的现成代码,则必须使用文本批量替换工具搜索
“POWERED BY……”
之类的版权特征信息,并进行替换,以免源代码存在漏洞时,别人可以通过搜索引擎快速找到你的网站,从而减少被随意入侵的机率。
9 E( H7 g# I/ v% M U1 U) v
4 m" d. ?9 E5 n
6. MSSQL Server
的基本安全策略
6 j% {; [+ m; O' D' g/ u4 p
这些步骤是针对任何
SQL Server
安装的部分标准安全
“
最佳策略
”
。
9 K' J2 K# i: d4 W$ z
首先
,
打上
SQL SERVER
最新的安全补丁,现在补丁已经出到了
SP3
。下载地址:
sql/downloads/2000/sp3.asp" target=_blank>
http://www.microsoft.com/sql/downloads/2000/sp3.asp
。如果这一步都没有做好,那我们也没有继续下去的必要了。
5 N) c# C! }/ G9 d" i* _
; L1 M8 j7 q0 U
1.
确保你的
SA
登录帐号的密码非空。只有你的
SA
登录帐号没有安全保障的时候蠕虫才会工作。
" u7 [" R( j0 D9 |( K8 x1 B
因此,你应该遵循在
SQL Server
7 G: O/ b- i' k! z# F% o
联机文档中
“
系统管理员(
SA
)登录
”
主题中的推荐模式,确保固有的
SA
帐号具有一个强壮的密码,
1 E6 e9 G A* g( W: }' t
即使是你自己从不使用
SA
帐号。
0 W0 ?# a5 I9 v7 ?3 M: ^% [9 I4 I; }
2.
在你的互联网网关或防火墙上屏蔽
1433
端口和
/
或指定
SQL Server
监听一个可选的端口。
5 u+ x m$ }; d) y: T3 @
3.
假如在你的互联网网关上需要利用
1433
端口,启动用于防止此端口滥用的流入
/
流出过滤。
! s1 U- Z6 {. a1 Z# ]
4.
将
SQLServer
和
SQL Server
客户端运行在微软的
Windows NT
帐号下,而不是
localsystem
。
6 R% e# ~- I& X0 A5 f7 e7 Z7 W
5.
启动
Windows NT
验证,启动监听成功和失败的登录,然后停止并重启
MSSQLServer
服务。设置你的客户端使用
NT
验证。
7 a6 g- W+ n* ~# n5 x& S Y9 _
6.
改默认的
1433
端口,并且将
SQL SERVER
隐藏。这样能禁止对试图枚举网络上现有的
SQL Server
客户端所发出的广播作出响应。另外,还需要在
TCP/IP
筛选中将
1433
端口屏蔽掉,尽可能的隐藏你的
SQL SERVER
数据库。这样子一但让攻击创建了
SQL SERVER
的账号,也不能马上使用查询分析器远程登陆来进行下一步的攻击。单从
ASP
,
PHP
等页面构造恶意语句的话,还有需要查看返回值的问题,总比不上直接查询分析器来得利落。所以我们首先要做到即使让别人注入了,也不能让攻击者下一步做得顺当。修改方法:企业管理器
-->
你的数据库组
-->
属性
-->
常规
-->
网络配置
--> TCP/IP -->
属性 ,在这儿将你的默认端口进行修改,和
SQL SERVER
的隐藏。
h9 O* G. `' S2 x2 c/ l
7.
合理创建角色
" U/ ` w% E8 S, m" l& j5 k
SQL INJECTION
往往在
WEB CODE
中产生。而做为系统管理员或者数据库管理员,总不能常常的去看每一段代码。即使常常看代码,也不能保证我们在上面的疏忽。那怎么办?我们就要从数据库角色着手,让数据库用户的权限划分到最低点。
SQL SERVER
的默认权限让人真的很头疼,权限大得非常的高,权限小的又什么都做不了,
SYSADMIN
和
db_owner
真是让人又爱又恨。攻击者一但确认了网站存在
SQL INJECTION
漏洞,肯定有一步操作步骤就是测试网站的
SQL SERVER
使用者具有多大的权限。一般都会借助
SELECT IS_SRVROLEMEMBER(''sysadmin'')
,或者
SELECT IS_MEMBER(''db_owner'')
,再或者用
user = 0(
让字符和数字进行比较,
SQL SERVER
就会提示了错误信息,从该信息中即可知道一些敏感信息
)
等语句进行测试。方法还有,我也不敢多说了。其一怕错,其二怕联盟中的人扁。在当前,如果网站的数据库使用者用的是
SA
权限,再加上确认了
WEB
所处在的绝对路径,那么就宣告了你的网站的
OVER
。
db_owner
权限也一样,如果确认了绝对路径,那么有
50
%的机会能给你的机器中上
WEB
方式的木马,如海阳等。所以这儿我们确认了一点,我们必须要创建自已的权限,让攻击者找不着下嘴的地方。在这儿引用一个
SQL SERVER
联机帮助中的例子:
! t9 G! D6 c: u! D2 F2 K- z
& E4 z) O" u9 @ ^7 r5 {
创建
SQL Server
数据库角色的方法(企业管理器)
/ |' ^& o: h9 e
创建
SQL Server
数据库角色
8 Z3 U& a" k% Z N( h* r
1.
展开服务器组,然后展开服务器。
e4 o. v: E/ p6 J9 m% Z- k$ ?
2.
展开
"
数据库
"
文件夹,然后展开要在其中创建角色的数据库。
( o- u& B; Z: m6 L; U
3.
右击
"
角色
"
,然后单击
"
新建数据库角色
"
命令。
/ x# p" I3 ~8 G" B5 i2 }' l
4.
在
"
名称
"
框中输入新角色的名称。
G/ h& `" a5 D- D/ k2 P7 ]! t0 f
5.
单击
"
添加
"
将成员添加到
"
标准角色
"
列表中,然后单击要添加的一个或多个用户。(可选)
" T- k3 ]5 `5 Q2 N2 w) S1 e1 ^# a
只有选定数据库中的用户才能被添加到角色中。
. {3 @9 q" X7 H: l' |
8.
合理的权限配置
8 b z. q C2 R) Y- K
对象权限
+ ^5 e4 [: h! u* S. q9 I
处理数据或执行过程时需要称为对象权限的权限类别:
) z8 q2 ~5 z% h1 j4 h8 l6 h( J
· SELECT
、
INSERT
、
UPDATE
和
DELETE
语句权限,它们可以应用到整个表或视图中。
( w. }8 H ?! T% Z# E: ^
· SELECT
和
UPDATE
语句权限,它们可以有选择性地应用到表或视图中的单个列上。
0 K! p; T. T& `; h6 b5 X
· SELECT
权限,它们可以应用到用户定义函数。
: S& N* A# n. L1 W
· INSERT
和
DELETE
语句权限,它们会影响整行,因此只可以应用到表或视图中,而不能应用到单个列上。
; G9 K7 o( E8 I9 h
· EXECUTE
语句权限,它们可以影响存储过程和函数。
. z& g' X0 D$ L* ]8 `2 D: o
- ^7 M! @9 Y* S
语句权限
+ |1 Z3 d) k& K. s9 q$ j
创建数据库或数据库中的项(如表或存储过程)所涉及的活动要求另一类称为语句权限的权限。例如,如果用户必须能够在数据库中创建表,则应该向该用户授予
CREATE TABLE
语句权限。语句权限(如
CREATE DATABASE
)适用于语句自身,而不适用于数据库中定义的特定对象。
* ?+ ]7 Y4 _. @; _8 l. t
语句权限有:
$ X/ o8 \0 p2 o- m9 O" I- d
· BACKUP DATABASE
$ L% y2 ?9 ]! o! V/ B
· BACKUP LOG
! F0 L; u: p* x+ t) I& y- G
· CREATE DATABASE
; |+ h% i* A% Z# ?. D: ]7 q: i
· CREATE DEFAULT
' `, M4 I- X5 a4 r) C
· CREATE FUNCTION
4 I) _3 I4 w5 N7 D, n2 X: b
· CREATE PROCEDURE
. J: _+ l9 I. }) `9 U1 E1 T
· CREATE RULE
: A7 c4 r/ F" c9 c1 s, |' C
· CREATE TABLE
3 }# g4 K( Q& x3 U5 Y5 d, @& Y: r
· CREATE VIEW
8 b% v0 u& ]9 R& B# ?5 A0 o
" b4 D& D% {$ {* Q9 e0 S6 H8 S }
暗示性权限
+ ]5 k$ H0 K) _9 \+ |& g. N5 H
暗示性权限控制那些只能由预定义系统角色的成员或数据库对象所有者执行的活动。例如,
sysadmin
固定服务器角色成员自动继承在
SQL Server
安装中进行操作或查看的全部权限。
0 J( l. K5 r) L8 H
数据库对象所有者还有暗示性权限,可以对所拥有的对象执行一切活动。例如,拥有表的用户可以查看、添加或删除数据,更改表定义,或控制允许其他用户对表进行操作的权限。
+ Z& x2 }4 D+ y5 V9 `: i
- c1 ^% v/ A5 \+ g P
db_owner
在数据库中有全部权限。
9 `' k% U. I5 o( W; v0 l( u
db_accessadmin
可以添加或删除用户
ID
。
2 M* T& {' a) L* [
db_securityadmin
可以管理全部权限、对象所有权、角色和角色成员资格。
8 M; o3 r2 ?1 V1 l
db_ddladmin
可以发出
ALL DDL
,但不能发出
GRANT
、
REVOKE
或
DENY
语句。
Z! Z6 _# E; V
db_backupoperator
可以发出
DBCC
、
CHECKPOINT
和
BACKUP
语句。
3 c6 `' T& N1 j( f k7 {- h
db_datareader
可以选择数据库内任何用户表中的所有数据。
" Y' Q; N- ?- e% F8 `. ^
db_datawriter
可以更改数据库内任何用户表中的所有数据。
+ N+ K9 J# Z9 B0 i, `( l
db_denydatareader
不能选择数据库内任何用户表中的任何数据。
/ @) K- @9 v5 o8 e7 i8 x2 Z& o
db_denydatawriter
不能更改数据库内任何用户表中的任何数据。
- L3 T& a& b3 d7 ?
- K$ z1 z+ s4 M, w, Y2 G
在这儿把新建的数据库角色的权限配置好,比如需要使用哪个表、视图、存储过程等。然后把
Db_owner
和
db_securityadmin
、
db_backupoperator
取消,不给攻击者
BACKUP DATABASE
和
CREATE TABLE
的机会,一但攻击者具有这两个权限,那么你的网站就还处在十分危险的状态。还有注意一下,在创建数据库账号时,千万不能对服务器角色进行选择。
, b$ W0 f! k0 K. c+ }
9.
修改
SQL SERVER
内置存储过程。
SQL SERVER
估计是为了安装或者其它方面,它内置了一批危险的存储过程。能读到注册表信息,能写入注册表信息,能读磁盘共享信息等等
……
各位看到这儿,心里可能会在想,我的网站中有其它的代码,又不像查询分析器那样能查接将结果输出。给你这个权限,又不能怎么样,还是看不到信息。如果各位这样想就大错特错了。提示一下,如果攻击者有
CREATE TABLE
的权限,那么创建一个临时表,然后将信息
INSERT
到表中,然
SELECT
出来,接着跟数字进行比较,让
SQL SERVER
报错,那么结果就全出来了
……
所以我们要报着宁错杀,不放过的态度进行修补。
5 \ A, N8 t+ ]# T3 M. F1 Z3 j# d
% m$ W3 R5 M3 h
先来列出危险的内置存储过程:
6 O6 I2 N9 a& L7 ?* J8 A% E
- d3 n/ R$ ^6 J
xp_cmdshell
, I, Z# y( Z0 ?5 f+ }5 ~7 C. c
xp_regaddmultistring
6 ^% g% X% q1 F
xp_regdeletekey
9 W5 E8 r8 t2 k* p' R
xp_regdeletevalue
/ S( t$ @2 u6 N; _+ l; N$ L W
xp_regenumkeys
0 N! F5 d8 B n+ ^3 U: s- k
xp_regenumvalues
5 }3 z. l( m% {, y
xp_regread
+ h5 r* M+ o; I, z
xp_regremovemultistring
, h! Y0 [' K! h% W' U
xp_regwrite
$ D; j5 N( l! |( ]* P
& \ {9 _! V" ?( L2 H$ m3 V4 d6 k
ActiveX
自动脚本:
2 A! q s0 e9 B8 d( g
3 P; p; H6 t( J' M) X
sp_OACreate
V6 N8 d5 j7 |; x, a
sp_OADestroy
5 ~9 g) X F6 Z# G
sp_OAMethod
+ U- n- X. k @4 K
sp_OAGetProperty
1 H, S! D- i" p, J$ G
sp_OASetProperty
, H* m! Z! b* z/ l
sp_OAGetErrorInfo
8 e+ D: ?+ @$ i: X L: l3 T
sp_OAStop
: n% G: k& I @/ O& X% T
& w+ g. P$ U* H
以上各项全在我们封杀之列,例如
xp_cmdshell
屏蔽的方法为:
sp_dropextendedproc ''xp_cmdshell''
,如果需要的话,再用
sp_addextendedproc ''xp_cmdshell'', ''xpsql70.dll''
进行恢复。如果你不知道
xp_cmdshell
使用的是哪个
.dll
文件的话,可以使用
sp_helpextendedproc xp_cmdshell
来查看
xp_cmdshell
使用的是哪个动态联接库。另外,将
xp_cmdshell
屏蔽后,我们还需要做的步骤是将
xpsql70.dll
文件进行改名,以防止获得
SA
的攻击者将它进行恢复。
7 B0 Z2 P, a8 ?. g: L8 ?5 \$ t% I
欢迎光临 三千论坛 (http://3000y.com.cn/)
Powered by Discuz! X3.4