热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

用SSL构建一个安全的Apache

用SSL构建一个安全的Apache--Linux企业应用-Linux服务器应用信息,下面是详情阅读。
  一、简介

  这篇文章要说明的是如何将阿帕奇与SSL(Secure Socket Layer)结合起来安装配置。众所周知,在网络上以明文传递敏感信息是相当不安全的,因此SSL提供了一种加密手段,在底层上为上层协议提供服务和加密方案,因此当用户在以HTTP协议传输数据时,窥探者将难以获取数据的信息。当然加密只是在传输过程中的,对用户是完全透明的。
  
  那么就开始吧……
  
  二、准备工作
  
  如果你的系统是从头装起的话,建议你留出一个叫/chroot的分区用来运行Apache。至于这个分区的大小,取决于你自已,一般来说,一个普通的网站有40M也就够了。但你的系统如果早就运行了Apache,你可以另外开辟一个分区,或者选择不用独立分区来安装,仅仅在根下面开一个目录。
  
  另外我假定你的系统已经通过了一定的安全检测——在安装Apache之前(如果有其它漏洞存在的话,你认为运行在其上的Apache会怎样,所谓覆巢之下,焉有完卵,检测至少要包括(但不仅限于)——移除不安全的SUID程序、升级某些守护进程,去掉不必要的服务。还假定你是的WEB SERVER是运行TCP/IP而且有自己的地址。
  
  三、平台
  
  以下测试都在下列平台下通过:
  
  1、Slackware 4.x distribution using gcc 2.7.2.3 and Perl v5.005_02
  
  2、Solaris 7 on Sparc using gcc v2.8.1 and Perl v5.005_03
  
  四、获取所需要的软件
  
  因为阿帕奇并没有在她的包里自己SSL,因此我们必须先下载到这些加密网页所必需的部份:
  
  1、Apache Web Server - http://www.apache.org/dist/
  
  不必多说,我们当然需要获得这个web server,现在的版本是1.3.11,阿帕奇是现在世界上使用最广泛的web server。
  
  2、mod_ssl - http://www.modssl.org
  
  这是一个为Apache1.3.x web server提供强力加密的的软件模块,它使用的是SSL v2和v3以及TLS(Transport Layer Security)v1 协议。该软件包是在BSD的license下开发的,在非商业的情况下,你可以自由地使用它,要判断该使用哪一个版本的mod_ssl很简单,它的版本号是-格式的,也就是说,你如果用的是1.3.11的Apache,那么就该用2.50-1.3.11的mod_ssl。
  
  3、mod_perl - http://perl.apache.org/dist/
  
  4、Open SSL - http://www.openssl.org
  
  这一软件包提供了SSL v2/v3(Secure Sockets Layer)及TLS v1(Transport Layer Security)协议的加密保护。
  
  5、RSAref - 用搜索引擎查找一下"rsaref20.tar.Z"应该就能找到了
  
  我们将把这些程序安装于/usr/local目录下增加功能模块可以给阿帕奇更强大的功能,如果你需要更多的模块的话,自己去获得它并且加载,比如mod_php这一模块也是现在流行的,可以使阿帕奇提供php脚本支持……
  
  五、软件包的安装
  
  在实际安装前我们要决定我们将把web server安装在什么环境下,对于一个对安全有相当高要求的人来说,可以将服务器和软件安装于chroot环境,chroot改变root 目录并且仅在这一目录中执行程序,这提供了一个内建的小环境,即使入侵者已经通过cgi程序或者其它办法通过80端口获得了系统的进入权限,它也只能够在这一受限的环境中活动,从安全角度考量,这当然是最好的,但对系统管理员来说,这样安装相对麻烦一些,还必须把一些必要的库,perl以及相关工具也搬到chroot中,所以——你自己决定吧,这里我们介绍的是在chroot下安装。
  
  展开这些软件包:
  
  #gzip -d -c apache_1.3.11.tar.gz | tar xvf -
  
  #gzip -d -c mod_ssl-2.5.0-1.3.11.tar.gz | tar xvf -
  
  #gzip -d -c openssl-0.9.4.tar.gz | tar xvf -
  
  #gzip -d -c mod_perl-1.21.tar.gz | tar xvf -
  
  展开并且编译rsaref
  
  #mkdir rsaref
  
  #cd rsaref
  
  #gzip -d -c ../rsaref20.tar.Z | tar xvf -
  
  #tar xvf rsaref.tar
  
  #cp -rp install/unix temp
  
  #cd temp
  
  #make
  
  #mv rsaref.a librsaref.a
  
  #cd ../../
  
  编译OpenSSL
  
  #cd openssl-0.9.4
  
  #perl util/perlpath.pl /usr/bin/perl (Path to Perl)
  
  #./config -L`pwd`/../rsaref/temp/
  
  #make
  
  #make test
  
  #cd ..
  
  将mod_perl加到Apache的编译选项里
  
  #cd mod_perl-1.21
  
  #perl Makefile.PL APACHE_PREFIX=/usr/local/apache
  APACHE_SRC=../apache_1.3.11/src
  USE_APACI=1
  
  你会得到下面的提示:
  
  Configure mod_perl with ../apache_1.3.11/src ? [y]
  
  直接按enter就是默认的yes
  
  然后Makefile会问你是否建立httpd,可以用n选择不。
  
  #make
  
  #make install
  
  #cd ..
  
  将mod_ssl加到Apache中
  
  #cd mod_ssl-2.5.0-1.3.11
  
  #./configure --with-apache=../apache_1.3.11
  --prefix=/usr/local/apache
  --with-ssl=../openssl-0.9.4
  --with-rsa=../rsaref/temp
  --activate-module=src/modules/perl/libperl.a
  
  #cd ..
  
  编译Apache:
  
  #cd apache_1.3.11
  
  在编译以前我们可以再做一件事——编辑包含http server版本号的文件,使想得到它的入侵者摸不着脑袋长哪儿
  
  # src/include/httpd.h
  
  寻找下面的行 (approx. 454)并且改变server的名字及版本号——可以随便用你想改成的东西。
  
  define SERVER_BASEVERSION "Apache/1.3.11"
  
  现在你可以编译阿帕奇了
  
  #make
  
  现在你可以生成一个CA了(actual certificate).
  
  #make certificate
  
  按照该授权书的安装介绍做。
  
  #make install
  
  这将会把阿帕奇装在/usr/local/apache。
  
  测试web server (还没装SSL)是否运行正常 ----调用web server:
  
  /usr/local/apache/bin/apachectl start
  
  当WEB服务器运行起来后,你可以用 lynx或者任意什么浏览器连接你的80端口,如果能看到apache的欢迎页,就OK了。
  
  停止server:
  
  /usr/local/apache/bin/apachectl stop
  
  测试web server (同时起SSL) - 调用带SSL的WEB服务器
  
  /usr/local/apache/bin/apachectl startssl
  
  服务器运行时你用Netscape或者其它支持SSL的浏览器来看http://your.ip.here,看到欢迎页了么?
  
  要停止SERVER:
  
  /usr/local/apache/bin/apachectl stop
  
  六、阿帕奇的配置
  
  现在我们可以来看看阿帕奇的配置文件了——需要记住的是如果你对它做了更改,在未重新启动httpd守护进程前,它是不会发生作用的。好,现在我们可以进目录/usr/local/apache/conf看看了。
  
  httpd.conf -
  
  这是阿帕奇的主要配置文件,你可以在这里设定服务器启动时的基本环境,比如服务器的启动方式、端口号、允许的最多连接数等等,这一文件的注释非常详细,要看明白应该没什么问题。
  
  access.conf -
  
  这一文件是设定系统中的存取方式和环境的,但现在已经可以在httpd.conf中设定了,所以推荐你别动它,放空好了。
  
  srm.conf -
  
  这家伙主要做的是资源上的设定,你也可以放空,仅仅设定httpd.conf中的相关项。
  
  现在重启web server来使改动生效:
  
  #/usr/local/apache/bin/apachectl restart
  
  七、将阿帕奇设定在chroot环境下
  
  现在我们开始把刚才建立的东西移到chroot环境下——包括阿帕奇服务器以及所有需要的库文件。当然如前面所说的,这部份是可选的,如果你怕麻烦的话就算了,但转移后可以对你的web server多一个可靠的保护。
  
  建立/chroot目录
  
  #mkdir /chroot
  
  建立一些必需的子目录
  
  #mkdir /chroot/dev
  
  #mkdir /chroot/lib
  
  #mkdir /chroot/etc
  
  #mkdir /chroot/bin
  
  #mkdir /chroot/usr
  
  #mkdir /chroot/usr/local
  
  在我们的chroot建立/dev/null
  
  #mknod -m 666 /chroot/dev/null c 1 3
  
  将阿帕奇拷贝到/chroot目录中
  
  #cp -rp /usr/local/apache/ /chroot/usr/local
  
  拷贝必需的二进制文件
  
  #cp /bin/sh /chroot/bin
  
  确定哪些库是必需的——这取决于你编译时内建了哪些模块
  
  #ldd /usr/local/apache/bin/httpd
  
  将需要的库拷贝到chroot目录
  
  #cp /lib/libm.* /chroot/lib/
  
  #cp /lib/libgdbm.* /chroot/lib
  
  #cp /lib/libdb.* /chroot/lib
  
  #cp /lib/libdl.* /chroot/lib
  
  #cp /lib/libc.* /chroot/lib
  
  拷贝网络连接所需要的函数库
  
  #cp /lib/libnss* /chroot
推荐阅读
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • PHP组合工具以及开发所需的工具
    本文介绍了PHP开发中常用的组合工具和开发所需的工具。对于数据分析软件,包括Excel、hihidata、SPSS、SAS、MARLAB、Eview以及各种BI与报表工具等。同时还介绍了PHP开发所需的PHP MySQL Apache集成环境,包括推荐的AppServ等版本。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 腾讯安全平台部招聘安全工程师和数据分析工程师
    腾讯安全平台部正在招聘安全工程师和数据分析工程师。安全工程师负责安全问题和安全事件的跟踪和分析,提供安全测试技术支持;数据分析工程师负责安全产品相关系统数据统计和分析挖掘,通过用户行为数据建模为业务决策提供参考。招聘要求包括熟悉渗透测试和常见安全工具原理,精通Web漏洞,熟练使用多门编程语言等。有相关工作经验和在安全站点发表作品的候选人优先考虑。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文介绍了关于apache、phpmyadmin、mysql、php、emacs、path等知识点,以及如何搭建php环境。文章提供了详细的安装步骤和所需软件列表,希望能帮助读者解决与LAMP相关的技术问题。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • php课程Json格式规范需要注意的小细节
    JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgramming ... [详细]
author-avatar
辰S辰_588
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有