zoukankan      html  css  js  c++  java
  • 隐藏apache和php的版本

    第一个隐藏apache和php版本的经典,隐藏apache和php版本是服务器管理人员和程序员必回的,多的不说了,现在我们就开始自己动 手学习怎样隐藏apache版本和隐藏php版本吧!其实隐藏apache版本和php版本很简单,简单的就是两句话,那为什么我还要写这么多呢?那是因 为我写了很多废话,好了,我们现在进入正题,开始学习隐藏apache和php版本了,O(∩_∩)O哈哈哈~
    第一讲开拍:
    隐藏apache和php的版本信息,web server避免一些不必要的麻烦,可以把apache和php的版本信息不显示

    隐藏 Apache 版本信息

    /etc/apache2/apache2.conf 或 /etc/httpd/conf/httpd.conf

    ServerTokens ProductOnly
    ServerSignature Off

    重启 apache
    现在 http 头里面只看到:
    Server: Apache

    隐藏 PHP 版本
    php.ini

    expose_php On
    改成
    expose_php Off

    重启apache后,php版本在http头中隐藏了。

    详解 :

    为了防止某些别有用心的家伙窥视我们的服务器,应该做些什么.
    我们来看一下相关的2个参数,分别为ServerTokens和ServerSignature,通过控制这2个阀门应该就能起到一些作用,比如我们可以在配置文件中这么写:
    ServerTokens Prod
    ServerSignature Off

    ServerTokens
    用于控制服务器是否相应来自客户端的请求,向客户端输出服务器系统类型或内置模块等重要的系统信息。 在主配置文件中提供全局控制默认阀值为"Full"(ServerTokens Full),所以,如果你的Linux发行版本没有更改过这个阀值的话,所有与你的系统有关的敏感信息都会向全世界公开。比如RHEL会将该 阀值更改为"ServerTokens OS",而Debian依然使用默认的"Full"阀值
    以apache-2.0.55为例,阀值可以设定为以下某项(后面为相对应的Banner Header):
    Prod >>> Server: Apache
    Major >>> Server: Apache/2
    Minor >>> Server: Apache/2.0
    Minimal >>> Server: Apache/2.0.55
    OS >>> Server: Apache/2.0.55 (Debian)
    Full (or not specified) default >>> Server: Apache/2.0.55 (Debian) PHP/5.1.2-1+b1 mod_ssl/2.0.55 OpenSSL/0.9.8b

    ServerSignature
    控制由系统生成的页面(错误信息,mod_proxy ftp directory listing等等)的页脚中如何显示信息。

    可在全局设置文件中控制,或是通过.htaccess文件控制
    默认为"off"(ServerSignature Off),有些Linux发行版本可能会打开这个阀门,比如Debian在默认的虚拟主机上默认将这个阀门设置为开放
    全局阀门的阀值会被虚拟主机或目录单位的配置文件中的阀值所覆盖,所以,必须确保这样的事情不应该发生 .

    第二讲开拍:嘿嘿

    Apache服务器走到那里,unix/linux就跟到那里,这足以说明在WEB服务器领域Apache的优良性能与市场占有率
    这今天互联网的大环境下,web服务已经成为公司企业必不可少的业务,大多数的安全问题也跟随而来,攻击重点也转移为web攻击,许多web与颇有价值的客户服务与电子商业活动结合在一起,这也是吸引恶意攻击重要原因。
    先来了解下web所面临的安全风险
    HTTP拒绝服务攻击
    攻击者通过某些手段使服务器拒绝对http应答,这使Apache对系统资源(cup时间与内存)需求巨增,最终造成系统变慢甚至完全瘫痪,Apache服务器最大的缺点是,它的普遍性使它成为众矢之的,Apache服务器无时无刻不受到DoS攻击威胁,主要有下边几种
    1.数据包洪水攻击
    一种中断服务器或本地网络的方法是数据包洪水攻击,它通常使用internet控制报文协议(ICMP,属于网络层协议)
    包 或是udp包,在最简单的形式下,这些攻击都是使服务器或网络负载过重,这意味这攻击者的网络速度必须比目标主机网络速度要快,使用udp包的优势是不会 有任何包返回到黑客的计算机(udp效率要比tcp高17倍),而使用ICMP包的优势是攻击者能让攻击更加富与变化,发送有缺陷的包会搞乱并锁住受害者 的网络,目前流行的趋势是攻击者欺骗服务器,让其相信正在受来自自身的洪水攻击
    2.磁盘攻击
    这是一种很不道德的攻击,它不仅影响计算机的通信,还破坏其硬件,伪造的用户请求利用写命令攻击目标计算机硬盘,让其超过极限,并强制关闭,结局很悲惨
    3.路由不可达
    通常DoS攻击,集中在路由器上,攻击者首先获得控制权并操纵目标机器,当攻击者能更改路由表条目时候,会导致整个网络无法通信,这种攻击很阴险,隐蔽,因为网络管理员需要排除的网络不通原因很多,其中一些原因需要详细分辨
    4.分布式拒绝服务攻击
    这 也是最具有威胁的DDoS攻击,名称很容易理解,简单说就是群欧,很多客户机同时单条服务器,你会发现你将伤痕累累,Apache服务器特别容易受到攻 击,无论是DDos还是隐藏来源的攻击,因为Apache无处不在,特别是为Apache特意打造的病毒(特选SSL蠕虫),潜伏在许多主机上,攻击者通 过病毒可以操纵大量被感染的机器,对特定目标发动一次浩大的DDoS攻击,通过将蠕虫散播到大量主机,大规模的点对点攻击得以进行,除非你不提供服务,要 不然几乎无法阻止这样的攻击,这种攻击通常会定位到大型的网站上。
    缓冲区溢出,这种攻击很普遍,攻击者利用CGI程序编写一些缺陷程序偏离正常的流程,程序使用静态的内存分配,攻击者就可以发送一个超长的请求使缓冲区溢出,比如,一些perl编写的处理用户请求的网关脚本,一但缓冲区溢出,攻击者就可以执行恶意指令
    非法获取root权限
    如 果Apache以root权限运行,系统上一些程序的逻辑缺陷或缓冲区溢出漏洞,会让攻击者很容易在本地系统获取linux服务器上的管理者权限,在一些 远程情况下,攻击者会利用一些以root身份执行的有缺陷的系统守护进程来取得root权限,或利用有缺陷的服务进程漏洞来取得普通用户权限,以远程登 陆,进而控制整个系统。
    这边这些都是服务将会遇到的攻击手段,下边来说,如何打造安全的Apache服务器
    如果你能遵守下边这些建议,那么你将得到一台相对安全的apache服务器
    一:勤打补丁
    你必须要相信这个是最有用的手段,缓冲区溢出等漏洞都必须使用这种手段来防御,勤快点相信对你没有坏处
    在http:www.apache.org上最新的changelog中都写有:bug fix ,security bug fix的字样,做为负责任的管理员要经常关注相关漏洞,及时升级系统添加补丁。使用最新安全版本对加强apache至关重要
    二:隐藏和伪装Apache的版本
    通常,软件的漏洞信息和特定版本是相关的,因此,版本号对黑客来说是最有价值的。
    默认情况下,系统会把Apache版本模块都显示出来(http返回头)。如果列举目录的话,会显示域名信息(文件列表正文),去除Apache版本号的方法是修改配置文件/etc/httpd.conf。找到关键字ServerSignature,将其设定为:
    ServerSignature Off
    ServerTokens Prod

    然后重新启动Apache服务器。
    通过分析Web服务器的类型,大致可以推测出操作系统的类型,比如,Windows使用IIS来提供HTTP服务,而Linux中最常见的是Apache。

    默认的Apache配置里没有任何信息保护机制,并且允许目录浏览。通过目录浏览,通常可以获得类似“Apache/1.3.27 Server at apache.linuxforum.net Port 80”或“Apache/2.0.49 (Unix) PHP/4.3.8”的信息。
    通 过修改配置文件中的ServerTokens参数,可以将Apache的相关信息隐藏起来。但是,Red Hat Linux运行的Apache是编译好的程序,提示信息被编译在程序里,要隐藏这些信息需要修改Apache的源代码,然后,重新编译安装程序,以替换里 面的提示内容。

    以Apache 2.0.50为例,编辑ap_release.h文件,修改“#define AP_SERVER_BASEPRODUCT \"Apache\"”为“#define AP_SERVER_BASEPRODUCT \"Microsoft-IIS/5.0\"”。
    编辑os/unix/os.h文件,修改“#define PLATFORM \"Unix\"”为“#define PLATFORM \"Win32\"”。
    修改完毕后,重新编译、安装Apache。
    Apache 安装完成后,修改httpd.conf配置文件,将“ServerTokens Full”改为“ServerTokens Prod”;将“ServerSignature On”改为“ServerSignature Off”,然后存盘退出。重新启动Apache后,用工具进行扫描,发现提示信息中已经显示操作系统为Windows。
    如ubuntu中文论坛
    Apache/2.2.8 (Ubuntu) DAV/2 SVN/1.4.6 mod_ssl/2.2.8 OpenSSL/0.9.8g Server at forum.ubuntu.org.cn Port 80
    这个等于告诉恶意用户很多有用信息,虽然说不算开了门,但等于被告诉了门在那里,还是相当危险的
    三:建立安全的目录结构apache服务器包括四个目录结构
    ServerRoot #保存配置文件,二进制文件与其他服务器配置文件
    DocumentRoot #保存web站点内容,包括HTML文件和图片等
    ScripAlias #保存CGI脚本
    Customlog 和 Errorlog #保存日志和错误日志
    建议的目录结构为,以上四种目录相互独立并且不存在父子逻辑关系
    注:
    ServerRoot目录只能为root用户访问
    DocumentRoot目录应该能够被管理web站点内容的用户访问和使用apache服务器的apache用户与组访问
    ScripAlias目录应该只能被CGI开发人员和apache用户访问
    Customlog 和 Errorlog只能被root访问
    下边是一个安全目录结构的事例
    +——-/etc/
    |
    | +—-/http (ServerRoot)
    | +—-/logs (Customlog 和 Errorlog)
    |
    +——-var/www
    |
    | +—/cgi-bin (ScripAlias)
    | +—/html(DocumentRoot)
    这样的目录结构是比较安全的,因为目录之间独立,某个目录权限错误不会影响到其他目录
    四:为apache使用专门的用户与组
    按照最小特权的原则,需要给apache分配一个合适的权限,让其能够完成web服务
    注:
    最小特权原则是系统安全中最基本的原则之一,限制使用者对系统及数据进行存取所需要的最小权限,保证用户可以完成任务,同时也确保被窃取或异常操作所造成的损失
    必须保证apache使用一个专门的用户与组,不要使用系统预定的帐户,比如nobody用户与nogroup组
    因 为只有root用户可以运行apache,DocumentRoot应该能够被管理web站点内容的用户访问和使用apache服务器的 apache用户与组访问,例如,希望“test”用户在web站点发布内容,并且可以以httpd身份运行apache服务器,可以这样设定
    groupadd webteam
    usermod -G webteam test
    chown -R httpd.webteam /www/html
    chmod -R 2570 /www/htdocs
    只有root能访问日志,推荐这样的权限
    chown -R [...]

    隐藏php头部版本输出 Hide PHP version (X-Powered-By)

    php默认会输出header信息:
    Date: Tue, 15 Apr 2008 13:58:46 GMT
    Server: Apache/2.2.8
    X-Powered-By: PHP/5.2.3
    这样一下子php信息就全曝光了。怎样解决呢。

    隐藏php头部版本输出 Hide PHP version (X-Powered-By)

    php默认会输出header信息:
    Date: Tue, 15 Apr 2008 13:58:46 GMT
    Server: Apache/2.2.8
    X-Powered-By: PHP/5.2.3
    这样一下子php信息就全曝光了。怎样解决呢。

    网上一搜中文,还真找不到相关信息。用英文一搜搜到了(下面是原文)
    If you have read my previous tip, “Hide apache software version“, you have seen how you can configure apache to provide only a minimal amount of information about the installed software versions in its banner. But if you are using the PHP module in your web server (as most of us are), then there is one additional step that need to be completed, and this is what I will show you in this tip.
    After implementing the apache directives ServerTokens and ServerSignature as shown in “Hide apache software version“, we test its functionality against a regular html file and we get the following response:

    HEAD http://remote_server.com/index.html
    200 OK
    Connection: close
    Date: Fri, 16 Jun 2006 01:13:23 GMT
    Server: Apache
    Content-Type: text/html; charset=UTF-8
    Client-Date: Fri, 16 Jun 2006 21:42:53 GMT
    Client-Peer: 192.168.0.102:80
    Client-Response-Num: 1

    This looks good. But if we do the same thing against an URL that is a PHP file:

    HEAD http://remote_server.com/index.php 200 OK Connection: close Date: Fri, 16 Jun 2006 01:16:30 GMT Server: Apache Content-Type: text/html; charset=UTF-8 Client-Date: Fri, 16 Jun 2006 21:48:13 GMT Client-Peer: 192.168.0.102:80 Client-Response-Num: 1 X-Powered-By: PHP/5.1.2-1+b1

    Ups… As we can see PHP adds its own banner:

    X-Powered-By: PHP/5.1.2-1+b1
    Let’s see how we can disable it. In order to prevent PHP from exposing the fact that it is installed on the server, by adding its signature to the web server header we need to locate in php.ini the variable expose_php and turn it off.

    By default expose_php is set to On.

    In your php.ini (based on your Linux distribution this can be found in various places, like /etc/php.ini, /etc/php5/apache2/php.ini, etc.) locate the line containing “expose_php On” and set it to Off:

    expose_php = Off

    After making this change PHP will no longer add it’s signature to the web server header. Doing this, will not make your server more secure… it will just prevent remote hosts to easily see that you have PHP installed on the system and what version you are running.
    结果简单的让人吃惊,只是需要修改php.ini 的 expose_php 把默认的 On改成 Off 就行了。

    from http://hi.baidu.com/lzqiang321/blog/item/98169b11cd1beccb277fb5ac.html

  • 相关阅读:
    预习笔记 多态 --S2 4.3
    织梦CMS标签生成器
    socketCluster 使用
    JS工具库之Lodash
    socketcluster 客户端请求
    AngularJS自定义指令directive:scope属性 (转载)
    angularjs报错问题记录
    Angularjs中的事件广播 —全面解析$broadcast,$emit,$on
    angularJS中directive与controller之间的通信
    AngularJs Type error : Cannot read property 'childNodes' of undefined
  • 原文地址:https://www.cnblogs.com/youlechang123/p/3125556.html
Copyright © 2011-2022 走看看