网站被注入的一些解决办法

最近看到很多人的网站都被注入js,iframe之类的。非常多。

本人曾接手过一个比较大的网站,被人家入侵了,要我收拾残局。。

1.
首先我会检查一下服务器配置,重新配置一次服务器安全,可以参考
Win2003 防木马、权限设置、IIS服务器安全配置整理

2009-02-10 10:45

一、系统的安装  

1、按照Windows2003安装光盘的提示安装,默认情况下2003没有把IIS6.0安装在系统里面。

2、IIS6.0的安装
  开始菜单—>控制面板—>添加或删除程序—>添加/删除Windows组件
  应用程序 ———ASP.NET(可选)
       |——启用网络 COM+ 访问(必选)
       |——Internet 信息服务(IIS)———Internet 信息服务管理器(必选) 
                   |——公用文件(必选)
                   |——万维网服务———Active Server pages(必选)
                              |——Internet 数据连接器(可选)
                              |——WebDAV 发布(可选)

                              |——万维网服务(必选)
                              |——在服务器端的包含文件(可选)
  然后点击确定—>下一步安装。
(具体见本文附件1

3、系统补丁的更新
  点击开始菜单—>所有程序—>Windows Update
  按照提示进行补丁的安装。


4、备份系统
  用GHOST备份系统。

5、安装常用的软件
  例如:杀毒软件、解压缩软件等;安装完毕后,配置杀毒软件,扫描系统漏洞,安装之后用GHOST再次备份系统。

6
、先关闭不需要的端口 开启防火墙 导入IPSEC策略
网络连接里,把不需要的协议和服务都删掉,这里只安装了基本的Internet协议(TCP/IP),由于要控制带宽流量服务,额外安装了Qos数据包计划程序。在高级tcp/ip设置里--"NetBIOS"设置"禁用tcp/IP上的NetBIOSS"。在高级选项里,使用"Internet连接防火墙",这是windows 2003 自带的防火墙,在2000系统里没有的功能,虽然没什么功能,但可以屏蔽端口,这样已经基本达到了一个IPSec的功能。

修改3389远程连接端口
修改注册表.
开始--运行
--regedit
依次展开
HKEY_LOCAL_MACHINE/SYSTEM/CURRENTCONTROLSET/CONTROL/
TERMINAL SERVER/WDS/RDPWD/TDS/TCP
右边键值中 PortNumber 改为你想用的端口号.注意使用十进制(
10000 )

HKEY_LOCAL_MACHINE/SYSTEM/CURRENTCONTROLSET/CONTROL/TERMINAL SERVER/
WINSTATIONS/RDP-TCP/
右边键值中 PortNumber 改为你想用的端口号.注意使用十进制(
10000 )
注意:别忘了在WINDOWS2003自带的防火墙给+10000端口

修改完毕.重新启动服务器.设置生效.

二、用户安全设置
1
、禁用Guest账号

在计算机管理的用户里面把Guest账号禁用。为了保险起见,最好给Guest加一个复杂的密码。你可以打开记事本,在里面输入一串包含特殊字符、数字、字母的长字符串,然后把它作为Guest用户的密码拷进去。

2
、限制不必要的用户
去掉所有的Duplicate User用户、测试用户、共享用户等等。
用户组策略设置相应权限,并且经常检查系统的用户,删除已经不再使用的用户。这些用户很多时候都是黑客们入侵系统的突破口。
3
、把系统Administrator账号改名
大家都知道,Windows 2003 Administrator用户是不能被停用的,这意味着别人可以一遍又一遍地尝试这个用户的密码。
尽量把它伪装成普通用户,比如改成Guesycludx
4
、创建一个陷阱用户

什么是陷阱用户?即创建一个名为“Administrator”的本地用户,把它的权限设置成最低,什么事也干不了的那种,并且加上一个超过10位的超级复杂密码。这样可以让那些 Hacker们忙上一段时间,借此发现它们的入侵企图。

5
、把共享文件的权限从Everyone组改成授权用户
任何时候都不要把共享文件的用户设置成“Everyone”组,包括打印共享,默认的属性就是“Everyone”组的,一定不要忘了改。

6、开启用户策略
使用用户策略,分别设置复位用户锁定计数器时间为20分钟,用户锁定时间为20分钟,用户锁定阈值为3次。 (该项为可选)

7
、不让系统显示上次登录的用户名
默认情况下,登录对话框中会显示上次登录的用户名。这使得别人可以很容易地得到系统的一些用户名,进而做密码猜测。修改注册表可以不让对话框里显示上次登录的用户名。方法为:打开注册表编辑器并找到注册表“HKLM/Software/Microsoft/Windows T/CurrentVersion/Winlogon/Dont-DisplayLastUserName”,把REG_SZ的键值改成1

密码安全设置

1
、使用安全密码

一些公司的管理员创建账号的时候往往用公司名、计算机名做用户名,然后又把这些用户的密码设置得太简单,比如“welcome”等等。因此,要注意密码的复杂性,还要记住经常改密码。

2
、设置屏幕保护密码

这是一个很简单也很有必要的操作。设置屏幕保护密码也是防止内部人员破坏服务器的一个屏障。

3
、开启密码策略

注意应用密码策略,如启用密码复杂性要求,设置密码长度最小值为6位 ,设置强制密码历史为5次,时间为42天。

4
、考虑使用智能卡来代替密码

对于密码,总是使安全管理员进退两难,密码设置简单容易受到黑客的攻击,密码设置复杂又容易忘记。如果条件允许,用智能卡来代替复杂的密码是一个很好的解决方法。

三、系统权限的设置
1、磁盘权限
  系统盘及所有磁盘只给 Administrators 组和 SYSTEM 的完全控制权限
  系统盘/Documents and Settings 目录只给 Administrators 组和 SYSTEM 的完全控制权限
  系统盘/Documents and Settings/All Users 目录只给 Administrators 组和 SYSTEM 的完全控制权限
  系统盘/Windows/System32/cacls.execmd.exenet.exenet1.exeftp.exetftp.exetelnet.exe        netstat.exeregedit.exeat.exeattrib.exeformat.comdel文件只给 Administrators 组和SYSTEM 的完全   控制权限  
另将/System32/cmd.exeformat.comftp.exe转移到其他目录或更名

  Documents and Settings下所有些目录都设置只给adinistrators权限。
并且要一个一个目录查看,包括下面的所有子目录。
删除c:/inetpub目录

2、本地安全策略设置
  开始菜单—>管理工具—>本地安全策略
  A、本地策略——>审核策略
  审核策略更改   成功 失败  

  审核登录事件   成功 失败
  审核对象访问      失败
  审核过程跟踪   无审核
  审核目录服务访问    失败
  审核特权使用      失败
  审核系统事件   成功 失败
  审核账户登录事件 成功 失败
  审核账户管理   成功 失败

  B、本地策略——>用户权限分配
  关闭系统:只有Administrators组、其它全部删除。
  通过终端服务允许登陆:只加入Administrators,Remote Desktop Users组,其他全部删除


  C、本地策略——>安全选项
  交互式登陆:不显示上次的用户名       启用
  网络访问:不允许SAM帐户和共享的匿名枚举  启用
  网络访问:不允许为网络身份验证储存凭证   启用
  网络访问:可匿名访问的共享         全部删除
  网络访问:可匿名访问的命          全部删除
  网络访问:可远程访问的注册表路径      全部删除
  网络访问:可远程访问的注册表路径和子路径  全部删除

  帐户:重命名来宾帐户            重命名一个帐户

  帐户:重命名系统管理员帐户         重命名一个帐户


3、禁用不必要的服务   开始-运行-services.msc
       TCP/IPNetBIOS Helper
提供 TCP/IP 服务上的 NetBIOS 和网络上客户端的 NetBIOS 名称解析的支持而使用户能够共享

      
文件、打印和登录到网络
       Server
支持此计算机通过网络的文件、打印、和命名管道共享
  Computer Browser 维护网络上计算机的最新列表以及提供这个列表
       Task scheduler
允许程序在指定时间运行

       Messenger
传输客户端和服务器之间的 NET SEND 和 警报器服务消息

  Distributed File System: 局域网管理共享文件,不需要可禁用

  Distributed linktracking client:用于局域网更新连接信息,不需要可禁用

  Error reporting service:禁止发送错误报告

  Microsoft Serch:提供快速的单词搜索,不需要可禁用

  NTLMSecuritysupportprovidetelnet服务和Microsoft Serch用的,不需要可禁用

  PrintSpooler:如果没有打印机可禁用

  Remote Registry:禁止远程修改注册表

  Remote Desktop Help Session Manager:禁止远程协助

       Workstation  
关闭的话远程NET命令列不出用户组

  以上是在Windows Server 2003 系统上面默认启动的服务中禁用的,默认禁用的服务如没特别需要的话不要启动。
4、修改注册表
修改注册表,让系统更强壮
1
、隐藏重要文件/目录可以修改注册表实现完全隐藏
HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/ Current-Version/Explorer/Advanced/Folder/Hi-dden/SHOWALL”
,鼠标右击 “CheckedValue”,选择修改,把数值由1改为0

2
、防止SYN洪水攻击

HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters
新建DWORD值,名为SynAttackProtect,值为
2
新建
EnablePMTUDiscovery REG_DWORD 0
新建
NoNameReleaseOnDemand REG_DWORD 1
新建
EnableDeadGWDetect REG_DWORD 0
新建
KeepAliveTime REG_DWORD 300,000
新建
PerformRouterDiscovery REG_DWORD 0
新建
EnableICMPRedirects REG_DWORD 0

3.
禁止响应ICMP路由通告报文

HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters/Interfaces/interface
新建DWORD值,名为PerformRouterDiscovery 值为
0

4.
防止ICMP重定向报文的攻击

HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters
EnableICMPRedirects 值设为
0

5.
不支持IGMP协议

HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters
新建DWORD值,名为IGMPLevel 值为
0
6
、禁止IPC空连接:

cracker
可以利用net use命令建立空连接,进而入侵,还有net viewnbtstat这些都是基于空连接的,禁止空连接就好了。
Local_Machine/System/CurrentControlSet/Control/LSA-RestrictAnonymous
把这个值改成”1”即可。

7
、更改TTL
cracker
可以根据ping回的TTL值来大致判断你的操作系统,如:
TTL=107(WINNT);
TTL=108(win2000);
TTL=127
128(win9x);
TTL=240
241(linux);
TTL=252(solaris);
TTL=240(Irix);
实际上你可以自己改的:HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/ParametersDefaultTTL REG_DWORD 0-0xff(0-255 十进制,默认值128)改成一个莫名其妙的数字如258,起码让那些小菜鸟晕上半天,就此放弃入侵你也不一定哦


8.
删除默认共享
    
有人问过我一开机就共享所有盘,改回来以后,重启又变成了共享是怎么回事,这是2K为管理而设置的默认共享,HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/LanmanServer/ParametersAutoShareServer类型是REG_DWORD把值改为0即可

9.
禁止建立空连接
默认情况下,任何用户通过通过空连接连上服务器,进而枚举出帐号,猜测密码。我们可以通过修改注册表来禁止建立空连接:

Local_Machine/System/CurrentControlSet/Control/LSA-RestrictAnonymous
的值改成”1”即可。


10
、建立一个记事本,填上以下代码。保存为*.bat并加到启动项目中
net share c$ /del
net share d$ /del
net share e$ /del
net share f$ /del
net share ipc$ /del
net share admin$ /del

5
IIS站点设置:
1
、将IIS目录&数据与系统磁盘分开,保存在专用磁盘空间内。
2、启用父级路径
3
、在IIS管理器中删除必须之外的任何没有用到的映射(保留asp等必要映射即可)

4
、在IIS中将HTTP404 Object Not Found出错页面通过URL重定向到一个定制HTM文件
5
Web站点权限设定(建议)
                 允许
                 不允许
脚本源访问         不允许
目录浏览         建议关闭
日志访问         建议关闭
索引资源         建议关闭
执行             推荐选择仅限于脚本
6
、建议使用W3C扩充日志文件格式,每天记录客户IP地址,用户名,服务器端口,方法,URI字根,HTTP状态,用户代理,而且每天均要审查日志。(最好不要使用缺省的目录,建议更换一个记日志的路径,同时设置日志的访问权限,只允许管理员和systemFull Control)。

7
、程序安全
:
1)
涉及用户名与口令的程序最好封装在服务器端,尽量少的在ASP文件里出现,涉及到与数据库连接地用户名与口令应给予最小的权限
;
2)
需要经过验证的ASP页面,可跟踪上一个页面的文件名,只有从上一页面转进来的会话才能读取这个页面。

3)
防止ASP主页.inc文件泄露问题;
4)
防止UE等编辑器生成some.asp.bak文件泄露问题。


6
IIS权限设置的思路
?
要为每个独立的要保护的个体(比如一个网站或者一个虚拟目录)创建一个系统用户,让这个站点在系统中具有惟一的可以设置权限的身份。
?
IIS的【站点属性或者虚拟目录属性目录安全性匿名访问和验证控制编辑匿名访问编辑】填写刚刚创建的那个用户名。

?
设置所有的分区禁止这个用户访问,而刚才这个站点的主目录对应的那个文件夹设置允许这个用户访问(要去掉继承父权限,并且要加上超管组和SYSTEM组)。


7
、卸载最不安全的组件
最简单的办法是直接卸载后删除相应的程序文件。将下面的代码保存为一个.BAT文件,( 以下均以 WIN2000 为例,如果使用2003,则系统文件夹应该是 C:/WINDOWS/ )
regsvr32/u C:/WINDOWS/System32/wshom.ocx
del C:/WINDOWS/System32/wshom.ocx
regsvr32/u C:/WINDOWS/system32/shell32.dll
del C:/WINNT/WINDOWS/shell32.dll

然后运行一下,WScript.Shell, Shell.application, WScript.Network就会被卸载了。可能会提示无法删除文件,不用管它,重启一下服务器,你会发现这三个都提示“×安全了。

http://www.ajiang.net/products/aspcheck/下载阿江的探针查看相关安全设置情况



2.
其次,用麦咖啡自定义策略,即使网站程序有漏洞,别人也很难在文件上写入代码了。
参考自定义策略,有了这个策略,再烂的程序,你也无法写入我的文件
http://hi.baidu.com/zzxap/blog/item/efe093a7e0f2c190d04358ef.html

3.
可以用网络超级巡警删除被注入的JS代码。
参考
http://hi.baidu.com/anlish/blog/item/ba45bb18eac77e0534fa4134.html

4.
如何批量删除数据库中被注入的代码?
在数据库查询分析器运行这段代码即可

SQL code

 

DECLARE @fieldtype sysname

SET @fieldtype='varchar'

--删除处理

DECLARE hCForEach CURSOR GLOBAL

FOR

SELECT N'update '+QUOTENAME(o.name)

    +N' set '+ QUOTENAME(c.name) + N' = replace(' + QUOTENAME(c.name) + ',''<script_src=http://ucmal.com/0.js> </script>'','''')'

FROM sysobjects o,syscolumns c,systypes t

WHERE o.id=c.id

    AND OBJECTPROPERTY(o.id,N'IsUserTable')=1

    AND c.xusertype=t.xusertype

    AND t.name=@fieldtype

EXEC sp_MSforeach_Worker @command1=N'?'

 

 



5.
创建一个触发器,只要有 </script>就不给插入,对性能会有点影响

SQL code

 

create trigger tr_table_insertupdate

on tablename

for insert,update

as

if exists (

select 1 from inserted

where data like '%</script>%'

)

begin

       RAISERROR ('不能修改或者添加',16,1);

       ROLLBACK TRANSACTION

end

go

 

 



6.
最重要的还是程序的写法,用参数化SQL或存储过程
例如

C# code

 

 protected void cmdok_Click(object sender, EventArgs e)

    {

        //添加信息

        StringBuilder  sql = new StringBuilder( " insert into m_phone ( pid,PhoneName,num,price,phonetype,onSellTime,color,weight,Video,Camera,phoneSize,phoneSystem,Memorysize,PhoneDesc,Standbytime,ScreenSize,Frequency,InputMethod,Soundrecord,gps,fm,mp3,email,Infrared,game,clock,Calendar,Calculator,Bluetooth)  ");

 

        sql.Append(" values (@pid,@TextPhoneName,@Textnum,@Textprice,@Dropphonetype2,@TextonSellTime,@Textcolor,@Textweight ");

       

        .................

 

        SqlParameter[] paras = { new SqlParameter("@pid", SqlDbType.Int, 4) ,

            new SqlParameter("@TextPhoneName", SqlDbType.NVarChar, 50) ,

            new SqlParameter("@Textnum", SqlDbType.Int, 4) ,

            new SqlParameter("@Textprice", SqlDbType.Int, 4) ,

            new SqlParameter("@Dropphonetype2", SqlDbType.VarChar, 20) ,

            new SqlParameter("@TextonSellTime", SqlDbType.DateTime, 8) ,

            new SqlParameter("@Textcolor", SqlDbType.VarChar, 20) ,

            new SqlParameter("@Textweight", SqlDbType.NVarChar, 50) ,

 

           ...........

        };

        string[] stra = {Dropphonetype.SelectedValue,TextPhoneName.Text , Textnum.Text, Textprice.Text, Dropphonetype2.SelectedValue, TextonSellTime.Text, Textcolor.Text, Textweight.Text,

            .............};

 

        int a=stra.Length;

        int j;

       

        for ( j = 0; j < a; j++)

        {

            paras[j].Value = stra[j];

          

        }

        int strpid = 0;

        string sqla = sql.ToString();

        try

        {

            SqlHelper.ExcuteNonQurey(sqla, CommandType.Text, paras);//执行添加数据

          

            strpid = Convert.ToInt32(SqlHelper.ExcuteSclare(sqla, CommandType.Text, paras));  //获取刚才插入的id

 

 

        }

        catch (SqlException ex)

        {

            cmdreturn.Text = ex.Message.ToString();

 

        }

 

        cmdreturn.Text = strpid.ToString();

 

。。。。。。。。。

 



7.
通过URL传递的参数要用加密解密

C# code

 

传输

string szTmp = "safdsfdsafdsfytrsd";

szTmp = Server.UrlEncode(szTmp);

接收

STRING STRA=Server.UrlDecode(request.querystring(szTmp));

 

 

 



8.
把要使用的参数处理一下单引号,再放到SQL里面 
 
例如 string stra=aa.replace("'","''")

 
用参数化SQL可以不用处理单引号
 
指定参数类型和过滤掉单引号,就可以杜绝99.9%入侵了


另外说一句:网上那些被人奉如圣经的过滤 update insert  等关键字的程序是用处不大的  upupdatedate 过滤掉 update还是update
还会造成不必要的麻烦

你可能感兴趣的:(windows,网络,服务器,Microsoft,IIS,internet)