当前位置: 首页 > article >正文

Linux-Apache静态资源

文章目录

      • 静态资源
      • 权限设置

https://i-blog.csdnimg.cn/blog_migrate/58966ddd9b29aabe8841f5ec34f0d31c.gif

🏡作者主页:点击!

🤖Linux专栏:点击!

⏰️创作时间:2024年11月20日11点21分

在这里插入图片描述

静态资源

Apache配置静态资源

可以在网页上配置一个静态的FTP服务器,让用户访问网页获取相对应的文件

mkdir -p /website/test    #创建相对应的文件
echo "This is the first resource for this website" > /website/test/test1
ln -s test1 test2    #创建软链接test2

vi /etc/httpd/conf.d/website.conf

<Directory "/website">
	Options Indexes FollowSymlinks    #如果目录下没有index.html文件,就展示当前目录的文件系统,也可以访问目录中软									连接文件
	AllowOverride None    #允许完全访问
	#Allow open access:
	Require all granted    #任意访问
</Directory>

<Directory "/test">    #此处的 Test 的 Website目录下的test
	Options Indexes FollowSymlinks    #如果目录下没有index.html文件,就展示当前目录的文件系统,也可以访问目录中软									连接文件
	AllowOverride None    #允许完全访问
	#Allow open access:
	Require all granted    #任意访问
</Directory>

:wq
systemctl restart httpd    #重启服务即可,之后就实现了最终效果
#浏览器输入 http://192.168.100.148:1000/test----就能看见对应的目录下的文件

#当 /website/test中不包含 demo.html 是时候才会通过 Options 链接文件,把目录文件当做静态资源
DirectoryIndex demo.html

alias /demo "/website/test"    #设置别名,访问 https://192.168.100.148:1000/demo,也就是访问 /website/test

权限设置

Apache静态页面设置权限

#方式1
#直接在配置文件里面进行权限规定

vi /etc/httpd/conf.d/website.conf

<Directory "/website/test">    #此处的 Test 的 Website目录下的test,控制权限就需要用完整路径了
	Options Indexes FollowSymlinks    #如果目录下没有index.html文件,就展示当前目录的文件系统,也可以访问目录中软									连接文件
	#AllowOverride None    #将完全允许完全访问注释掉
	#Allow open access:
	#Require all granted    #将任意访问权限注释掉

	<RequireAll>
		Require all granted
		Require not ip 222.139.31.81    #意思是除了本地公网的IP,其他都可以访问,此时也要把 /test改成完整的路径
	</RequireAll>

</Directory>

:wq
systemctl restart httpd    #重启服务即可,之后就实现了最终效果
#方式2
#在需要控制访问的目录下创建 .htaccess 文件实现权限规定

vi /etc/httpd/conf.d/website.conf

<Directory "/website/test">    #此处的 Test 的 Website目录下的test,控制权限就需要用完整路径了
	Options Indexes FollowSymlinks    #如果目录下没有index.html文件,就展示当前目录的文件系统,也可以访问目录中软									连接文件
	AllowOverride all    #将完全允许完全访问开启并设置为all,此时权限就全部放到指定目录的 .htaccess 文件中,不再使用.conf文件来设置权限
	#Allow open access:
	#Require all granted    #将任意访问权限注释掉

	#<RequireAll>
	#	Require all granted
	#	Require not ip 222.139.31.81    #意思是除了本地公网的IP,其他都可以访问
	#</RequireAll>

</Directory>
:wq

vi /website/test/.htaccess    #创建访问权限文件,控制哪个就在哪个下面创建对应的文件
	<RequireAll>
		Require all granted
		Require not ip 222.139.31.81    #意思是除了本地公网的IP,其他都可以访问,此时也要把 /test改成完整的路径
	</RequireAll>

systemctl restart httpd    #重启服务即可,之后就实现了最终效果
#方式3(此方法失败)
#基于账户设置,限制基于某个用户的访问,需要在页面所在目录进行配置

cd /website/test
htpasswd -cb .passwd test admin@123   #在当前的test目录中创建新的htpasswd文件,基于http基本认证,用来做安全保护

vi /website/test/.htaccess
	<RequireAll>
		Require all granted
		Require not ip 222.139.31.81    #意思是除了本地公网的IP,其他都可以访问,此时也要把 /test改成完整的路径
	</RequireAll>
	AuthType Basic    #认证类型明文认证
	AuthName "http test"    #认证提示框显示内容为 http test
	AuthUserFile "/website/test/.passwd"    #密码文件存放的位置
	Require user test    #用户为test

#此时的配置文件有两条访问限制:
1、控制公网IP的访问(当然此时我们没有服务器,配置不配置一样)
2、控制用户的访问

systemctl restart httpd    #重启服务即可,之后就实现了最终效果(最后此方法失败)


http://www.kler.cn/a/405431.html

相关文章:

  • 基于Boost库的搜索引擎
  • 钉钉免登录接口
  • ‌Kotlin中的?.和!!主要区别
  • 记录一些PostgreSQL操作
  • FFmpegFrameRecorder 切分视频文件时结束条件设置不当导致切分后的文件过短问题
  • 【优选算法】前缀和
  • 【SpringBoot】发送各种复杂格式的邮件
  • Centos 8, add repo
  • .net 8使用hangfire实现库存同步任务
  • 分布式锁RedissonClient应用
  • 某车企ASW面试笔试题
  • Linux tcpdump 详解教程
  • 海盗王集成网关和商城服务端功能golang版
  • 重构代码之引入本地扩展
  • 【IOS】编译缓存错误Library/Caches/com.apple.mobile.installd.staging
  • 直流电表精准计量,为光伏产业续航
  • 2025蓝桥杯(单片机)备赛--扩展外设之UART1的原理与应用(十二)
  • 分治法的魅力:高效解决复杂问题的利器
  • 什么是axios?怎么使用axios封装Ajax?
  • 第1章 初识SpringMVC
  • 【滑动窗口】至少有k个重复字符的最长子串
  • 系统思考—跳出症状看全局
  • 【linux013】文件操作命令篇 - less 命令
  • python使用 `importlib.resources` 管理资源文件
  • FPC柔性线路板与智能生活的融合
  • 【电路笔记 TMS320F28335DSP】时钟+看门狗+相关寄存器(功能模块使能、时钟频率配置、看门狗配置)