WEB服务器的架设,在linux有一个很著名的架构叫lamp:linux+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

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

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

 

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

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

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

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

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

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

虚拟目录

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

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

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

(1)便于访问。

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

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

(4)安全性好。

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


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

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

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

虚拟主机

是在一台服务器上运行多个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实现。

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

 

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

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

mkdir /var/www/baidu.com
echo “this is www.baidu.com’s web “> / var/www/baidu.com/index.htmlmkdir /var/www/qq.com
echo “this is www.qq.com’s web “> / var/www/qq.com/index.html

 

 

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

ServerAdmin

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


DocumentRoot

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

ServerName sss.dev

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

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

重新启动httpd服务

service  httpd  restart ,进行测试

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

 

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

cd   /etc/sysconfig/network-scripts
cp  ifcfg-eth0   ifcfg-eth0:0
vim   ifcfg-eth0:0
DEVICE=eth0:0
IPADDR=172.16.102.121

重启网卡服务

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

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

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

mkdir  /var/www/ip1 /var/www/ip2echo “ 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

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

<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>

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

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

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


编辑配置文件,

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

重启httpd服务测试

搭建完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。

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

文中若有错误,请多包含,后面会针对web安全漏洞的每个漏洞进行解析,当然自己也会加强学习。

转载于:https://blog.51cto.com/wt7315/1853791

Linux之apache服务搭建以及浅析web安全相关推荐

  1. linux下apache+SVN搭建完美版

    一 .先介绍一下Subversion和apache,apr,apr-util的关系 很多朋友初次接触Subversion时不是很理解subversion和apache的关系.         我在这里 ...

  2. Centos Apache服务搭建

    前言: 总结下搭建Apache服务 Apache相关文件: apache配置文件 /etc/httpd/conf/httpd.conf 默认网页保存位置 /var/www/html 日志保存位置 /v ...

  3. 第16章 Linux的常用服务搭建

    文章目录 文档配套视频讲解链接地址 **第16章 常用服务搭建** **16.1 TFTP服务器搭建** **16.2 Samba服务搭建** **16.3 SSH服务搭建** 16.4 xshell ...

  4. Linux 的Apache服务之https与网页重写

    https 1.https概述: HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是 ...

  5. linux重启Apache服务的常用命令

    最近项目人手不够,运维的工作,很多都是交给我来处理,顺便学习一下linux的 操作命令.今天分享2个点:Apache服务的常用linux命令和整理磁盘空间的linux命令. 一,使用linux命令重启 ...

  6. Linux下Apache服务的部署和配置

    目录 Apache服务的安装 yum源安装: 目录文件 源码包安装: 目录文件:

  7. Linux下 FastDFS服务搭建 记录安装与配置过程

    环境准备 服务器主机名 ip 说明 tracker 192.168.1.128 负载均衡服务 storage1 192.168.1.129 存储服务 storage2 192.168.1.130 存储 ...

  8. 【Linux】apache服务相关概念及安装

    文章目录 web服务概述 什么是apache httpd 工作模型 apache的安装及应用 1. apache的安装 2. 启动: 3. 设置开机启动: 4. 查看httpd的进程及端口号 http ...

  9. linux下FTP服务搭建(1)

    1.FTP介绍: FTP (File Transfer Protocol,文件传输协议)主要用来文件传输,尤其适用于大文件传输,提供上传下载功能 FTP官方网站:https://filezilla-p ...

最新文章

  1. html xhtml and css,HTML与XHTML的重要区别
  2. 【Paper】2020_含时延约束的多智能体系统二分一致性
  3. 微信小程序中input和picker之间切换导致input无法失去焦点
  4. 补充部分官方文档里没有的Client Library以及代码提示Schema更新(三)
  5. 最简单的基于FFMPEG的推流器附件:收流器
  6. linux中的改变bin级别,Linux常用命令
  7. 东南电子IPO过会:应收账款8023万 美的与格力未付款
  8. 计算机网络课制作双绞线实验,计算机网络实验报告(双绞线).doc
  9. C盘用户文件夹下的AppData文件夹里放的是什么?
  10. Proteus,keil5仿真运行stm32程序,流水灯详细教程
  11. 软件项目工作量评估方法简述之功能点方法(FPA)
  12. 一个功能超全的「登录认证」神器!
  13. 打印所有的水仙花数---初学c语言
  14. 【SLAM学习笔记4】卡方检验chi-square
  15. Gradle依赖本地aar包
  16. C++基础知识—— 基本输入输出
  17. 全国超级计算机排名500强每年发布几次,全球超级计算机500强榜单发布,中国排第几?...
  18. 基于jquery的五子棋单机版
  19. 下载AE插件时出错,为什么?
  20. 写了一个jquery.imagesview插件,支持图片拖动、缩放类似ACDSEE效果

热门文章

  1. “跨国视频造假窝点”曝光!这个大规模数据集,帮AI揪出99%换脸视频
  2. 微软联合创始人保罗·艾伦去世,曾说服比尔·盖茨辍学
  3. Google云也想为中国企业服务,正与腾讯浪潮谈合作
  4. ASP.NET MVC多语言 仿微软网站效果
  5. 使用reflux进行react组件之间的通信
  6. web 前端routine
  7. 别踩白块儿游戏源代码分析和下载(二)
  8. 启用DHCP中继代理程序 实现跨子网服务
  9. 传统服务化(SOA)与微服务(Micro Service)的融合之道 1
  10. 【机器学习笔记之六】Bagging 简述