Linux之apache服务搭建以及浅析web安全

  1. 云栖社区>
  2. 博客>
  3. 正文

Linux之apache服务搭建以及浅析web安全

科技小能手 2017-11-12 15:10:00 浏览866
展开阅读全文

WEB服务器的架设,linux有一个很著名的架构叫lamplinux+apache+mysql+php,就知道apache的分量了。

 

在搭建apache服务钱需要做DNS服务器

DNS的搭建http://wt7315.blog.51cto.com/10319657/1852795

http的详解http://wt7315.blog.51cto.com/10319657/1837595



apache

后台进程:httpd

脚本:/etc/rc.d/init.d/httpd

默认使用端口:80(http)443(https) 

所需RPM包:httpd 

配置路径:/etc/httpd/* 

默认网站存放路径:/var/www/*

优点:免费,稳定,速度快


先安装apache

wKioL1fegRbRABIUAADF3XYxRxM604.png


etc/httpd存放着apache的所有配置文件,/var/www是网页文件存放目录,一般在HTML


wKioL1fegVKCbsZfAABrhWNwheA041.png

vim /etc/httpd/conf/httpd.conf appach的主配置文件

 

httpd.conf配置文件主要由全局环境、主服务器配置和虚拟主机3个部分组成。每部分都有相应的配置语句,该文件所有配置语句的语法为“配置参数名称 参数值”的形式。

httpd.conf中每行包含一条语句,行末使用反斜杠“\”可以换行,但是反斜杠与下一行中间不能有任何其他字符(包括空白)

httpd.conf的配置语句除了选项的参数值以外,所有选项指令均不区分大小写,可以在每一行前用“#”号表示注释。 

wKioL1fegXmTf0FYAACgEQGBUB4972.png

如果能看见红色的redhat的测试页面,就证明你的安装没有问题,如果看不见,你就要从新安装,或者调试你的网络了,网页文件默认是放在/var/www/html中的,我们现在就自己去写个网页,简单的测试下

documentRoot 就是定义网站的默认网站存放目录


wKioL1fegZrhJdi6AAAt0ThzKJQ782.png


配置DNS,将地址解析到linux的ip地址(上篇的DNS已经解析过了)


wKiom1fegczwE511AAAkdDLZrGg866.png


 

虚拟目录


每个 Internet服务可以从多个目录中发布。通过以通用命名约定 (UNC) 名、用户名及用于访问权限的密码指定目录,可将每个目录定位在本地驱动器或网络上。虚拟服务器可拥有一个宿主目录和任意数量的其它发布目录。其它发布目录称为虚拟目录。

apacheconfig文件中documentRoot 后面的是apache在解析页面时候的根目录,如果在本机上同时存在两个工作目录那么如果不虚拟(alias)目录的话,需要不断修改documentroot的路径,然后重启apache,相当麻烦,解决这个问题的办法之一就是设置虚拟目录


虚拟目录虚拟目录有以下优点。

1)便于访问。

2)便于移动站点中的目录。

3)能灵活加大磁盘空间。

4)安全性好。

5)使用Alias选项可以创建虚拟目录。

 

1
2
3
4
  
mkdir /var/www/dns/
echo /var/www/dns > /var/www/dns
并在最后加上Alias/dns “/var/www/dns”


/dns是在url里输入的时候起个名字,/var/www/dns/dns名字的具体存放路径,中间的空格是TAB出来的。


wKioL1fegk7BV5G7AAAOV_A1vHE900.png


service httpd restart重启httpd服务并进行测试。


wKiom1fegmXjaOTYAAAV5ENVsPw545.png



虚拟主机

是在一台服务器上运行多个Web站点。

三种设定虚拟主机的方式


基于名称的虚拟主机

只需服务器有一个IP地址即可,所有的虚拟主机共享同一个IP,各虚拟主机之间通过域名进行区分。

但需要新版本的HTTP 1.1浏览器支持。这种方式已经成为建立虚拟主机的标准方式。


基于IP的虚拟主机

需要在服务器上绑定多个IP地址,然后配置Apache,把多个网站绑定在不同的IP地址上,访问服务器上不同的IP地址,就可以看到不同的网站。


基于端口号的虚拟主机

只需服务器有一个IP地址即可,所有的虚拟主机共享同一个IP,各虚拟主机之间通过不同的端口号进行区分。在设置基于端口号的虚拟主机的配置时,需要利用Listen语句设置所监听的端口。

 

 

1.配置基于域名的虚拟主机

创建步骤:

① 注册虚拟主机所要使用的域名

实现域名解析可以有两种方法:

在客户机上通过修改/etc/hosts文件实现。这是一种比较简单的方法,只需在/etc/hosts文件中加入下面两行

172.16.1.117   www. baidu.com

172.16.1.117   www.qq.com

(2) DNS服务器上通过配置DNS实现。

 

wKiom1fegomTd-rCAAAxQeUJCa0431.png


上次的dns配置,已经配置好了百度的域名解析,进行简单的添加和修改,就把qq的域名解析也配置好了。

 

② 创建所需的目录和默认首页文件

/usr目录下创建四个目录,分别用来存放两主机的网页和日志文件。操作如下:

1
2
3
4
5
mkdir /var/www/baidu.com
echo “this is www.baidu.com’s web “> / var/www/baidu.com/index.html
  
mkdir /var/www/qq.com
echo “this is www.qq.com’s web “> / var/www/qq.com/index.html


 wKioL1fegvOT3l2IAABBKjGwX18354.png

 

编辑/etc/httpd/conf/httpd.conf配置文件

ServerAdmin

你的地址如果服务器有任何问题将发信到这个地址, 这个地址会在服务器产生的某些页面中出现,例如,错误报告


DocumentRoot

放置服务文档的目录, 默认状态下,所有的请求都以这个目录为基础, 但是直接符号连接和别名可用于指向其他位置。

ServerName sss.dev

允许设置主机名如果与程序获得的不同,主机名将返回客户端(例如,用"www"代替主机真实的名字)。缺省情况下,并不需要指定这个ServerName参数,服务器将自动通过名字解析过程来获得自己的名字,但如果服务器的名字解析有问题(通常为反向解析不正确),或者没有正式的DNS名字,也可以在这里指定IP地址。当ServerName设置不正确的时候,服务器不能正常启动。 





修改配置文件,httpd.conf文件最后添加以下两台虚拟机

wKiom1fegxewryT8AABlej0PBIk876.png


重新启动httpd服务

service  httpd  restart ,进行测试

wKiom1fegzWxVOPVAAAdliwQZIk383.png

wKioL1feg0fx4733AAAaLI0J8Qc922.png


2.基于IP地址的虚拟主机

 

①为一块网卡绑定多个IP地址

1
2
3
4
5
cd   /etc/sysconfig/network-scripts
cp  ifcfg-eth0   ifcfg-eth0:0
vim   ifcfg-eth0:0
DEVICE=eth0:0
IPADDR=172.16.102.121



wKioL1feg2ThD0WDAAAuQuj2Ypg397.png


重启网卡服务

wKioL1feg4bSd33DAAC3I4iSfnc378.png


②注册虚拟主机所使用的域名

向基于名称的虚拟主机配置类似,配置DNS服务,将测试的网址分别指向到192.168.1.117192.168.1.18两个IP地址上,当然也可以编辑/etc/hosts文件

wKiom1feg5uwQOYXAAAc39G4xos755.png


③创建web站点根目录和默认首页文件

1
2
3
4
5
mkdir  /var/www/ip1 /var/www/ip2
  
  
echo “ this is 172.16.1.117’s  web”>/var/www/ip1/index.html
echo “ this is 172.16.1.118’s  web”>/var/www/ip2/index.html


wKioL1feg7GSxO19AAA_R3_hYWc922.png


④编辑/etc/httpd/conf/httpd.conf配置文件

1
2
3
4
5
6
7
8
9
<VirtualHost  192.168.1.117>  
ServerName    www.ip1.com 
DocumentRoot  /var/www/ip1
</VirtualHost>  
  
<VirtualHost 192.168.1.118
ServerName    www.ip2.com 
DocumentRoot   /var/www/ip2
</VirtualHost>


wKiom1fehALRadMMAAA5Nuoq5ew519.png




⑤重新启动httpd服务进行测试

wKiom1fehByiX2rtAAA_OLxcjOM353.png


3.配置基于端口号的虚拟主机

把基于域名的配置完,剩下的两种配置基本也相似


wKioL1fehECStYrGAABT9zGSxtc144.png



编辑配置文件,

保证有以下Listen指令,并配置虚拟主机


wKioL1fehJWzYBHZAAA6rSMTi4M668.png


重启httpd服务测试

wKioL1fenVvjcE8mAABETr5q63o459.png


搭建完web服务,可以使用之外,就该考虑安全性了。

随着Web2.0、社交网络、微博等等一系列新型的互联网产品的诞生,基于Web环境的互联网应用越来越广泛,企业信息化的过程中各种应用都架设在Web平台上web安全也迅速得到强烈关注。


现状原因

  由于TCP/IP的设计是没有考虑安全问题的,这使得在网络上传输的数据是没有任何安全防护的。攻击者可以利用系统漏洞造成系统进程缓冲区溢出,攻击者可能获得或者提升自己在有漏洞的系统上的用户权限来运行任意程序,甚至安装和运行恶意代码,窃取机密数据。而应用层面的软件在开发过程中也没有过多考虑到安全的问题,这使得程序本身存在很多漏洞,诸如缓冲区溢出、SQL注入等等流行的应用层攻击,这些均属于在软件研发过程中疏忽了对安全的考虑所致。

  用户对某些隐秘的东西带有强烈的好奇心,一些利用木马或病毒程序进行攻击的攻击者,往往就利用了用户的这种好奇心理,将木马或病毒程序捆绑在一些艳丽的图片、音视频及免费软件等文件中,然后把这些文件置于某些网站当中,再引诱用户去单击或下载运行。或者通过电子邮件附件和QQ、MSN等即时聊天软件,将这些捆绑了木马或病毒的文件发送给用户,利用用户的好奇心理引诱用户打开或运行这些文件。

  管理员的配置不当,基于用户输入的一切都是不可靠的,很多的漏洞是管理员设置不当,过滤不严造成,当然,永远没有完美的程序。


web安全的范围太广,出于小白阶段的我也正在学习研究,后面后对每个漏洞进行研究,但是基本上每个网站都存在以下的漏洞。

(1)跨站脚本攻击(XSS)

 XSS攻击,通常指黑客通过“html注入” 篡改了网页,插入了恶意的脚本,从而在用户浏览网页的时候,控制用户浏览器的一种攻击。


最常见的XSS攻击就是通过读取浏览器的Cookie对象,从而发起“cookie劫持”,当前用户的登录凭证存储于服务器的session中,而在浏览器中是以cookie的形式进行存储的,cookie被劫持后,意味着攻击者可以不通过密码而直接登录系统。我们也可以直接在浏览器中输入脚本javascript:alert(document.cookie)来获取当前cookie值。


目前防止“cookie劫持”的方法大致有:a. 输入检查,使用filter来过滤敏感的关键字;b. 将cookie与用户ip地址进行绑定;c. 为cookie植入HttpOnly标识。


(2)SQL注入攻击

http://wt7315.blog.51cto.com/10319657/1828167

http://wt7315.blog.51cto.com/10319657/1841241

关于sql注入,写过两篇很详细的sql注入和sql注入神器sqlmap的介绍。

Sql注入的的两个关键条件:第一个是用户能够控制输入;第二个是原本程序要执行的代码,拼接了用户输入的数据。


根据上面两个关键条件,系统为防止sql注入使用了以下方法:


第一:使用预编译语句,这也是防御sql注入最有效的方法,完全摒弃代码的直接拼接所带来的危险。

第二:关闭web服务器的错误回显功能,这样可以防止攻击者对系统进行攻击后,通过回显的详细错误信息对攻击内容进行调整,对攻击者提供极大的便利。我们在项目的web.xml文件中添加以下示例代码:


第三:数据库自身使用最小权限原则,系统程序不使用最高权限的root对数据库进行连接,而是使用能满足系统需求的最小权限账户进行数据库连接,而且多个数据库之间使用不同的账户,保证每个数据库都有独立对应的账户。


(3)文件上传漏洞


文件上传漏洞是指用户上传了一个可执行的脚本文件,并通过脚本文件获得了执行服务器端命令的能力,这样将会导致严重的后果。而本系统内涉及到大量的图片格式文件上传,因此对于上传问题的处理非常谨慎,并尽可能的达到安全标准。


本系统主要通过对上传文件详细的格式验证:


第一步:通过后缀名来简单判断文件的格式。

第二步:通过读取文件的前两个字符进行对比,例如png格式图片的前两个字符为8950,而jpg格式的图片前两个字符为ffd8。

第三步:如果上传的为图片,则获取相应的高度和宽度,如果存在相应的宽度和高度则可认为上传的是图片。



本文转自 wt7315 51CTO博客,原文链接:http://blog.51cto.com/wt7315/1853791

网友评论

登录后评论
0/500
评论
科技小能手
+ 关注