Nginx配置防盗链主要有以下几种方法:
valid_referers指令valid_referers指令可以用来指定允许访问资源的来源。如果请求的来源不在指定的列表中,Nginx将返回403 Forbidden状态码。
server {
listen 80;
server_name example.com;
location /protected/ {
valid_referers none blocked server_names example.com www.example.com;
if ($invalid_referer) {
return 403;
}
# 其他配置...
}
}
ngx_http_referer_module模块这个模块提供了更灵活的防盗链功能,可以通过正则表达式来匹配来源。
server {
listen 80;
server_name example.com;
location /protected/ {
referer "http(s)?://(www\.)?example\.com(/.*)?";
if ($invalid_referer) {
return 403;
}
# 其他配置...
}
}
ngx_http_x_sendfile_module模块这个模块可以用来防止直接访问文件,而是通过Nginx服务器来处理请求。
server {
listen 80;
server_name example.com;
location /protected/ {
x_sendfile on;
internal;
# 其他配置...
}
}
ngx_http_realip_module模块这个模块可以用来隐藏真实的客户端IP地址,并且可以结合valid_referers指令来实现防盗链。
server {
listen 80;
server_name example.com;
set_real_ip_from 192.168.1.0/24;
real_ip_header X-Forwarded-For;
location /protected/ {
valid_referers none blocked server_names example.com www.example.com;
if ($invalid_referer) {
return 403;
}
# 其他配置...
}
}
有一些第三方模块可以提供更强大的防盗链功能,例如ngx_http_security_module。
server {
listen 80;
server_name example.com;
location /protected/ {
security on;
security_key "your_secret_key";
# 其他配置...
}
}
通过以上方法,你可以有效地防止他人盗用你的资源。根据具体需求选择合适的防盗链策略。