Nginx配置限制图片只能通过APP(Android/IOS)和网页中访问,不允许直接访问

关键点:

(1)在Nginx中通过user_agent区分请求来源是Android还是IOS。

(2)通过referer来源,判断图片是网页中访问还是直接访问图片,因为如果在网页中加载图片带有referer请求参数表明网页域名(或者IP地址),直接在浏览器中打开图片是没有携带referer请求参数的。

配置文件内容:

   server {
        listen       8000;

        location / {
            root   /opt/root;
            index  index.html index.htm;
        }
		
		location /img {
            ###通过判断Android还是iOS
			if ($http_user_agent ~* iPhone|Android){
				root /opt;
				break;
				#return 500;
			}
			#root /opt;
			##判断图片请求来源
			valid_referers none blocked YOUR_HOST;
			if ($invalid_referer ~* 0){#注意if和(之间的空格,不然会报错
				return 404;
				#root /opt;
			}
			if ($invalid_referer ~* 1){#注意if和(之间的空格,不然会报错
				root /opt;
			}
		}
    }
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Nginx配置访问图片路径和静态页面非常简单。以下是一个示例配置文件的示例: ``` server { listen 80; server_name yourdomain.com; root /path/to/your/website; location /images { alias /path/to/your/images; autoindex on; } location /static { alias /path/to/your/static/files; autoindex on; } location / { try_files $uri $uri/ /index.html; } } ``` 在上述配置文件,我们定义了一个虚拟主机,监听80端口,并使用`yourdomain.com`作为服务器名。 - 配置访问图片路径:使用`location /images`指令来配置访问图片的路径。将`/path/to/your/images`替换为实际存储图片的目录路径。如果需要显示图片列表,可以使用`autoindex on`指令。 - 配置访问静态页面:使用`location /static`指令来配置访问静态页面的路径。将`/path/to/your/static/files`替换为实际存储静态页面的目录路径。同样,如果需要显示文件列表,可以使用`autoindex on`指令。 - 其他路径:对于其他路径,我们使用`location /`指令,并使用`try_files`指令来尝试查找匹配的URI,如果找不到则返回`index.html`。你可以将`index.html`替换为你的默认页面。 请确保在配置文件替换实际的路径和域名,然后使用`nginx -s reload`命令重新加载配置文件,以使配置生效。 以上配置允许通过`yourdomain.com/images`访问图片文件和列表,通过`yourdomain.com/static`访问静态页面和文件,还可以通过`yourdomain.com`访问默认页面或其他匹配的页面。 希望以上信息能够帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值