Nginx設(shè)置Referer來防止盜圖的實(shí)現(xiàn)方法
如果服務(wù)器的圖片被別的網(wǎng)站盜鏈,將影響服務(wù)器的帶寬以及訪問速度,這時(shí)我們就需要設(shè)置圖片文件或視頻文件的防盜鏈功能;
防盜鏈功能,簡單來說就是你可以直接訪問該資源,但是不能將我的資源鏈接放到你自己的服務(wù)器上讓別人訪問,尤其是圖片或視頻這種比較大的文件,容易導(dǎo)致服務(wù)器響應(yīng)很慢。
如果不是圖床,還真怕別的網(wǎng)站直接使用本站圖片。這樣子流量很可能一下子就被刷光了,畢竟CDN都是白花花的銀子買來的。 因此,還是設(shè)置一個防盜鏈吧,Nginx就可以完成這個功能了。
一般來說,遵照HTTP協(xié)議實(shí)現(xiàn)的瀏覽器,在從A網(wǎng)站訪問B網(wǎng)站時(shí),都會帶上當(dāng)前網(wǎng)站的URL,以表明此次點(diǎn)擊是從何而起的。因此, Nginx的這個模塊也是依靠這個來實(shí)現(xiàn),所以,如果駭客不加此頭部,還是沒法愉快的防盜圖。
Nginx官網(wǎng)文檔如下:
Syntax: valid_referers none | blocked | server_names | string ...;
Default: —
Context: server, location
nginx referer指令簡介
nginx模塊ngx_http_referer_module通常用于阻擋來源非法的域名請求.我們應(yīng)該牢記,偽裝Referer頭部是非常簡單的事情,所以這個模塊只能用于阻止大部分非法請求.我們應(yīng)該記住,有些合法的請求是不會帶referer來源頭部的,所以有時(shí)候不要拒絕來源頭部(referer)為空的請求.
因此,我們可以在 server 或者 location 塊加上代碼,我是保存為 valid_referers.conf :
valid_referers none blocked server_names; if ($invalid_referer) { return 403; }
然后在對應(yīng)需要的地方加上 include /etc/nginx/valid_referers.conf ,當(dāng)然,執(zhí)行這個的前提是已經(jīng)把 valid_referers.conf 放到對應(yīng)機(jī)器上的 /etc/nginx/valid_referers.conf 路徑下。
示例:
location /articles/img { include /etc/nginx/valid_referers.conf; root /data/blog/code; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Debian下搭建Nginx和Tomcat服務(wù)器實(shí)現(xiàn)負(fù)載均衡的方案
這篇文章主要介紹了Debian下搭建Nginx和Tomcat服務(wù)器實(shí)現(xiàn)負(fù)載均衡的方案,其主要思想依然是動靜分離并且以Nginx來進(jìn)行反向代理這樣的路子,需要的朋友可以參考下2015-12-12Nginx隱藏版本號與網(wǎng)頁緩存時(shí)間的方法
這篇文章主要介紹了Nginx優(yōu)化之隱藏版本號與網(wǎng)頁緩存時(shí)間的方法,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11全面了解Nginx中的HTTP協(xié)議相關(guān)模塊配置
HTTP的處理是Nginx服務(wù)器的最重要功能,這里我們就帶大家來全面了解Nginx中的HTTP協(xié)議相關(guān)模塊配置,需要的朋友可以參考下2016-07-07nginx的location配置導(dǎo)致網(wǎng)關(guān)返回404問題
這篇文章主要介紹了nginx的location配置導(dǎo)致網(wǎng)關(guān)返回404問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06