h5ai 是用于 HTTP Web 服务器的现代文件索引器,专注于您的文件。目录以吸引人的方式显示,浏览它们通过不同的视图、面包屑和树概述得到增强。最初h5ai是HTML5 Apache Index的首字母缩写,但现在它也支持其他Web服务器。
有许多可用的扩展和配置选项,允许用户自定义目录列表的Web外观。所有标记均为有效的HTML5,并附带有CSS3和最佳的JavaScript,这些可以用来构建新鲜且注重用户体验的文件视图。
一些可选功能包括:
文件排序
不同的视图模式
本地化
痕迹导航
树视图
自定义页眉和页脚
文件过滤器和搜索
文件夹大小
自动刷新
打包下载
二维码
缩略图
文件预览
本次实践为个人测试环境,操作系统版本为centos7.6。
hostname | 本地P地址 | 操作系统版本 | 内核版本 | node版本 |
---|---|---|---|---|
jeven | 192.168.3.166 | centos 7.6 | 3.10.0-957.el7.x86_64 | v16.17.0 |
1.本次实践部署环境为个人测试环境;
2.在centos7.6环境下部署h5ai文件展示页。
检查本地操作系统版本
[root@jeven ~]# cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core)
检查系统内核版本
[root@jeven ~]# uname -r
3.10.0-957.el7.x86_64
如果没有镜像源,可以使用阿里云的镜像源。
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo
检查yum仓库状态,确保各镜像源正常。
[root@jeven ~]# yum repolist enabled
Loaded plugins: fastestmirror, langpacks
Determining fastest mirrors
* epel: cdn.centos.no
repo id repo name status
!base/7/x86_64 CentOS-7 - Base - mirrors.aliyun.com 10,072
!epel/x86_64 Extra Packages for Enterprise Linux 7 - x86_64 13,768
!extras/7/x86_64 CentOS-7 - Extras - mirrors.aliyun.com 518
!mysql-connectors-community/x86_64 MySQL Connectors Community 227
!mysql-tools-community/x86_64 MySQL Tools Community 100
!mysql57-community/x86_64 MySQL 5.7 Community Server 678
!updates/7/x86_64 CentOS-7 - Updates - mirrors.aliyun.com 5,287
repolist: 30,650
直接使用yum安装httpd软件。
yum -y install httpd
启动httpd服务,并使开机自启。
systemctl start httpd
systemctl enable httpd
查看httpd服务,确保httpd服务正常。
[root@jeven ~]# systemctl status httpd
● httpd.service - The Apache HTTP Server
Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; vendor preset: disabled)
Active: active (running) since Sat 2023-10-07 20:28:35 CST; 8s ago
Docs: man:httpd(8)
man:apachectl(8)
Main PID: 59236 (httpd)
Status: "Processing requests..."
CGroup: /system.slice/httpd.service
├─59236 /usr/sbin/httpd -DFOREGROUND
├─59237 /usr/sbin/httpd -DFOREGROUND
├─59238 /usr/sbin/httpd -DFOREGROUND
├─59239 /usr/sbin/httpd -DFOREGROUND
├─59240 /usr/sbin/httpd -DFOREGROUND
└─59241 /usr/sbin/httpd -DFOREGROUND
Oct 07 20:28:35 jeven systemd[1]: Starting The Apache HTTP Server...
Oct 07 20:28:35 jeven systemd[1]: Started The Apache HTTP Server.
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
setenforce 0
systemctl stop firewalld && systemctl disable firewalld
浏览器打开:http://192.168.3.166,将IP替换为自己服务器IP地址。
卸载旧版本的php,防止与新装的php7.4版本冲突。
yum remove -y php*
使用以下命令,安装remi镜像源。
yum -y install http://rpms.remirepo.net/enterprise/remi-release-7.rpm
接yum安装php7.4版本及其模块组件。
yum install -y --showduplicate --enablerepo=remi --enablerepo=remi-php74 php-fpm php php-cli php-bcmathphp-gd php-json php-mbstring php-mcrypt php-mysqlnd php-opcache php-pdo php-pecl-crypto php-pecl-mcrypt php-pecl-geoip php-recode php-snmp php-soap php-xml php-pecl-zip
查看当前的php版本
[root@jeven ~]# php -v
PHP 7.4.33 (cli) (built: Aug 1 2023 09:00:17) ( NTS )
Copyright (c) The PHP Group
Zend Engine v3.4.0, Copyright (c) Zend Technologies
with Zend OPcache v7.4.33, Copyright (c), by Zend Technologies
创建下载目录
mkdir -p /data/h5ai/ && cd /data/h5ai/
下载h5ai软件包
wget --no-check-certificate https://release.larsjung.de/h5ai/h5ai-0.30.0.zip
解压h5ai软件包
unzip h5ai-0.30.0.zip
将_h5ai目录复制到/var/www/html下
cp -a _h5ai/ /var/www/html/
将目录授权
chown -R apache:apache /var/www/html/
备份httpd配置文件
cp /etc/httpd/conf/httpd.conf /etc/httpd/conf/httpd.conf.bak
修改httpd配置文件,在/etc/httpd/conf/httpd.conf文件中的模块添加以下内容:
index.php /_h5ai/public/index.php
重启httpd服务与 php-fpm并设置开机自启
systemctl start php-fpm httpd && systemctl enable php-fpm httpd
访问地址:http://IP地址/_h5ai/public/index.php
当前密码为空,登录即可看到所有模块自检结果。
yum install -y ImageMagick
rpm --import http://li.nux.ro/download/nux/RPM-GPG-KEY-nux.ro
rpm -Uvh http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noarch.rpm
yum install ffmpeg ffmpeg-devel -y
yum install -y --showduplicate --enablerepo=remi --enablerepo=remi-php74 php-common php-devel php-gd
systemctl restart php-fpm httpd
刷新页面,可以看到所有功能模块都已经正常。
访问地址:http://192.168.3.166/,将IP替换为自己服务器IP地址。
在网站根目录/var/www/html,新建以下目录。
mkdir {movie,image,pdf,file}
上传文件到对应目录,目录内容如下:
[root@jeven html]# tree -L 2 ./
./
├── file
│ └── \344\272\221\350\256\241\347\256\227.docx
├── _h5ai
│ ├── CHANGELOG.md
│ ├── private
│ ├── public
│ └── README.md
├── image
│ └── \344\270\255\347\247\213\345\233\276\347\211\207.jpg
├── index.php
├── movie
│ ├── 694448a4-cf6a-4105-8694-f5f8da384e2c_SD.mp4
│ └── \346\210\221\346\234\200\351\227\252\344\272\256\ .mp3
└── pdf
└── \344\272\221\350\256\241\347\256\227\344\273\213\347\273\215.pdf
7 directories, 8 files
刷新网页,可以看到新建的目录。
测试目录中各种格式文件: