linux ftp web服务器搭建,Linux系统下搭建Web服务器和FTP服务器

66b52468c121889b900d4956032f1009.png

8种机械键盘轴体对比

本人程序员,要买一个写代码的键盘,请问红轴和茶轴怎么选?

Apache2和php组件的安装

使用如下命令来安装Apache2和php的组件

Ps:如果只安装Apache2,将会导致写的php文件无法被解析apt-get install apache2

apt-get install php

45cc6d1f765edbfc8937db402ae3554c.png

命令状态:/etc/init.d/apache2 status(service apache2 status)

开启:/etc/init.d/apache2 start(service apache2 start)

关闭:/etc/init.d/apache2 stop(service apache2 stop)

重启:/etc/init.d/apache2 restart(service apache2 restart)

987c3423e93b55fdb6fe9c68fac8ff16.png

网站根目录

网站根目录位于:/var/www/html

创建文件时,一些文件记得修改文件对应的权限,才能访问

登录验证

Apache2带有登录验证的功能,(1) 在/etc目录下创建.Webpasswd文件,设置登陆使用的用户名和密码。该文件为验证使用的储存用户名密码的文件

cfe49815a4a51ff477fb04181295bada.png

修改/etc/apache2/sites-available/000-default.conf文件,修改内容如下图所示。

450597de2647dd2cb8bd8ca036f3eaca.png

修改完成后再去访问就会看到弹出身份认证框

fe9572b48b3856e48f575decb95a1e5a.png

FTP服务器安装与配置

vsftpd组件的安装

使用如下命令来安装Apache2的组件apt-get install vsftpd

7f687ceed7f512bc9481e8175262307d.png

命令查看状态:/etc/init.d/vsftpd status

开启:/etc/init.d/vsftpd start

关闭:/etc/init.d/vsftpd stop

重启:/etc/init.d/vsftpd restart

配置

创建专门用于上传下载的目录(记得设置权限,不然会导致无法创建文件)

341d7f7994b66557b4965ce4544339aa.png

创建新用户并设置密码

284e136f8bc8761b75efaed6a0052a4c.png

修改配置文件 etc/vsftp.conf ,在文件头添加如下内容

5fd3ede4f7237f4e0ab9003f97e6f6c4.png

取消掉 write_enable=YES 的注释,使其生效,不然无法写入文件

6f5c352cd79f18c6a59b4904e5815907.png

新建 /etc/allowed_users 文件,添加允许访问的用户,我们在文件中添加我们刚才创建的用户 uftp

ee24c60c4f5536a4014ff24bb9c315e9.png

可以查看 /etc/ftpusers 文件,文件中的列表是禁止访问的用户

c0f9257fcf083f3e2b58065f90ba657f.png

重启 vsftpd 服务,并查看状态

2-8.png

安装 ftp 命令apt-get install ftp

2-01.png

至此,vsftp 服务器就安装完成了,下面简单演示一下如何用命令传输文件

使用

通过 ftp + IP地址 命令访问FTP服务;输入正确的用户名和密码进入服务;通过 put 命令来上传指定的文件。如图所示,本次实验将提前准备好的位于用户根目录下的 FTP_Success.gif 文件上传,(local-file)选项填写我们要上传的文件及其所处位置,(remote-file)选项填写文件上传后的位置

2-9.png

通过 netstat -atunp | grep ftp 命令来查看ftp服务使用的端口号

2-10.png

在我们的客户端(也就是我的Windows 10物理机),利用 LeapFTP 软件来连接服务器(也就是我的Kali Linux虚拟机)提供的FTP服务。在主界面点击左上角的 FTP->Quick Connect 来建立新连接

2-11.png

在弹出来的对话框中输入,服务器的IP地址、端口号(默认21)、Username、Password。这里的用户名密码填写我们刚才创建的那个用户(既 uftp 这个用户)

2-12.png

确定后,等待一段时间,就可以在主界面的右侧看到成功连接,并且文件夹里有我们刚才上传的文件:FTP_Success.gif。

2-13.png

可以右击我们想要下载的目标文件,点击 Download 来下载。下载目录可以在主界面的左侧选择,如下图,我们成功将 FTP_Success.gif 文件下载到了我物理机的桌面上。

2-14.png

前面有提到 /etc/allowed_users 文件是允许访问FTP服务器的用户列表,而 /etc/ftpusers 是禁止访问FTP服务器的用户列表,现在我们看一下两个列表的名单

2-15.png

可以看到现在允许访问的只有 uftp 怎么一个用户,而 root 用户是禁止访问的。现在我们在 LeapFTP 上,用 root 用户登录验证一下。可以看到,是登录失败的

2-16.png

现在我们将 root 用户添加到允许访问名单中,然后再登录试一下

9f03c657a2d428b26016bfbf9b1c2f61.png

2-18.png

可以看到在我们将 roor 用户添加到允许访问名单,并将之在禁止访问名单中去除后,就可以访问 FTP 服务器了,所以证明允许访问和禁止访问的名单还是有生效的。现在我们用 Wireshark 抓包来看一下 FTP 协议从建立连接到下载文件的完整过程

如下图可见TCP的三次握手建立的过程。FTP分为利用TCP和UDP两类,可以看出来我们本次实验使用的是可靠地TCP

2-19.png

可以看到从第981个包开始,客户端向FTP服务器发起请求,这就是我后来的下载操作

2-20.png

我们可以选中Protocol类型为FTP-DATA的数据包,右击->追踪流->TCP流,来查看完整的TCP流数据

2-21.png

从本TCP流中可看出,都是服务器向客户端发送数据,并且传输的内容为一张gif图片

dcbb09a73bafd22eab5d3e6cde221a09.png

可以将这个数据流以原始数据的方式保存下来,并命名为 wireshark.gif

9d377b799e09a3b3f1167bdd28b27059.png

借助工具 winhex 将抓取下来的图片的十六进制与我们原本用来测试的 FTP_Success.gif 对比一下,不仅可以用gif图片的格式打开查看,而且内容没有半点差异

2-24.png

2-25.png

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值