亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP設(shè)置images目錄不充許http訪問(wèn)的方法

 更新時(shí)間:2016年11月01日 11:39:54   投稿:mrr  
圖片防盜鏈可以防止其它網(wǎng)站盜用你的圖片,浪費(fèi)你寶貴的流量。下面通過(guò)本文給大家介紹PHP防止圖片盜用/盜鏈的兩種方法,第一種方法Apache圖片重定向方法,第二種方法設(shè)置images目錄不充許http訪問(wèn),具體詳細(xì)介紹可以參考下本文

防盜鏈的技術(shù)已經(jīng)很普遍了,有些網(wǎng)站不喜歡自己的圖片被別的網(wǎng)站直接復(fù)制使用,便使用了防盜鏈的技術(shù),這樣別人在直接復(fù)制使用網(wǎng)站圖片時(shí),圖片便會(huì)按照程序的設(shè)定不顯示或顯示防盜鏈等字樣。

如今的互聯(lián)網(wǎng),采集網(wǎng)站非常多,很多網(wǎng)站都喜歡盜鏈/盜用別人網(wǎng)站的圖片,這樣不僅侵犯網(wǎng)權(quán),還導(dǎo)致被盜鏈的網(wǎng)站消耗大量的流量,給服務(wù)器造成比較大的壓力,本文章向大家介紹php如何防止圖片盜用/盜鏈的兩種方法,需要的朋友可以參考一下。

圖片防盜鏈有什么用? 防止其它網(wǎng)站盜用你的圖片,浪費(fèi)你寶貴的流量。本文章向大家介紹php防止圖片盜用/盜鏈的兩種方法

1.Apache圖片重定向方法

2.設(shè)置images目錄不充許http訪問(wèn)

Apache服務(wù)器下防止圖片盜鏈的辦法

如果你的網(wǎng)站以圖片為主,哪天發(fā)現(xiàn)月底沒(méi)到流量就快用光了,那就可以利用圖片轉(zhuǎn)向,在不修改網(wǎng)頁(yè)的前提下,把圖片下載請(qǐng)求轉(zhuǎn)向到其它空間(比如試用主機(jī)),臨時(shí)過(guò)渡。

下面開(kāi)始講解,比如你的圖片都在img目錄下,那就在該目錄下放一個(gè)名為 .htaccess 的文件,內(nèi)容如下:

RewriteEngine on
RewriteCond %{HTTP_REFERER} !^$ [NC]
RewriteCond %{HTTP_REFERER} !simcole.cn [NC]
RewriteCond %{HTTP_REFERER} !zhuaxia.com [NC]
RewriteCond %{HTTP_REFERER} !google.com [NC]
RewriteCond %{HTTP_REFERER} !baidu.com [NC]
RewriteCond %{HTTP_REFERER} !bloglines.com [NC]
/* 作者:碼農(nóng)教程 http://www.manongjc.com */
RewriteRule .(jpg|gif|png|bmp|swf|jpeg) /image/replace.gif [R,NC,L]
RewriteRule ^(.*)$ http://image.simcole.cn/image/$1 [L]

大概解釋下:

RewriteCond %{HTTP_REFERER} !^$ [NC]
RewriteCond %{HTTP_REFERER} !simcole.cn [NC]
RewriteCond %{HTTP_REFERER} !zhuaxia.com [NC]
RewriteCond %{HTTP_REFERER} !google.com [NC]
/* 作者:碼農(nóng)教程 http://www.manongjc.com/article/1550.html */
RewriteCond %{HTTP_REFERER} !baidu.com [NC]
RewriteCond %{HTTP_REFERER} !bloglines.com [NC]

這部分是判斷是否盜鏈,如果以上條件都成立(即訪問(wèn)圖片的請(qǐng)求,既不是直接輸入網(wǎng)址,也不是來(lái)自simcole.cn,也不是來(lái)自zhuaxia.com,也不是來(lái)自google.com,也不是來(lái)自baidu.com,也不是來(lái)自bloglines.com 的話),就執(zhí)行下列轉(zhuǎn)向:

RewriteRule .(jpg|gif|png|bmp|swf|jpeg) /image/replace.gif [R,NC,L]

意思是讓所有盜鏈 img 目錄下 jpg、gif、png、bmp、swf、jpeg 文件的網(wǎng)頁(yè),顯示的圖片都用 image 目錄下的 replace.gif 圖片替換掉。注意替換顯示的圖片不要放在設(shè)置防盜鏈的 img 目錄下。如果照上面的規(guī)則判斷出圖片請(qǐng)求不是盜鏈的,就執(zhí)行以下轉(zhuǎn)向:

RewriteRule ^(.*)$ http://image.simcole.cn/image/$1 [L]

意思是對(duì) img 目錄下所有的請(qǐng)求都轉(zhuǎn)向到目標(biāo)服務(wù)器,比如有個(gè)圖片原來(lái)的 url 是 http://www.bebecn.com/img/girl.jpg ,現(xiàn)在就會(huì)轉(zhuǎn)到 http://image.bebecn.com/image/girl.jpg 去。當(dāng)然了你得先把原服務(wù)器 img 目錄下的文件統(tǒng)統(tǒng)拷貝到臨時(shí)服務(wù)器的 image 目錄下,轉(zhuǎn)向才會(huì)真正可用。起到的效果就是把原服務(wù)器圖片下載所占用的流量統(tǒng)統(tǒng)省下,讓臨時(shí)服務(wù)器來(lái)承受了.

設(shè)置images目錄不充許http訪問(wèn)

把images目錄設(shè)置成不充許http訪問(wèn)(把圖片目錄的:讀取、目錄瀏覽 兩個(gè)權(quán)限去掉)。

用一個(gè)PHP文件,直接用file函數(shù)讀取這個(gè)圖片。在這個(gè)PHP文件里進(jìn)行權(quán)限控制。

apache環(huán)境中,在你的圖片目錄中加上下面這個(gè)文件即可。

文件名 .htaccess

文件內(nèi)容如下

# options the .htaccess files in directories can override.
# Edit apache/conf/httpd.conf to AllowOverride in .htaccess
# AllowOverride AuthConfig
# Stop the directory list from being shown
Options -Indexes
# Controls who can get stuff from this server.
Order Deny,Allow
Deny from all
Allow from localhost

其他web環(huán)境如iss,nginx也類似。

class imgdata{
public $imgsrc;
public $imgdata;
public $imgform;
public function getdir($source){
$this->imgsrc = $source;
}
public function img2data(){
$this->_imgfrom($this->imgsrc);
return $this->imgdata=fread(fopen($this->imgsrc,'rb'),filesize($this->imgsrc));
}
public function data2img(){
header(“content-type:$this->imgform”);
echo $this->imgdata;
//echo $this->imgform;
//imagecreatefromstring($this->imgdata);
}
public function _imgfrom($imgsrc){
$info=getimagesize($imgsrc);
//var_dump($info);
/* 作者:碼農(nóng)教程 http://www.manongjc.com */
return $this->imgform = $info['mime'];
}
}
$n = new imgdata;
$n -> getdir(“1.jpg”); //圖片路徑,一般存儲(chǔ)在數(shù)據(jù)庫(kù)里,用戶無(wú)法獲取真實(shí)路徑,可根據(jù)圖片ID來(lái)獲取
$n -> img2data();
$n -> data2img();

這段代碼是讀取圖片,然后直接輸出給瀏覽器,在讀取和輸出之前,進(jìn)行用戶權(quán)限判斷。

這里說(shuō)的PHP讀取圖片,不是指讀取路徑,而是指讀取圖片的內(nèi)容,然后通過(guò)

Header();輸入圖片類型,比如 gif png jpg等,下面輸出圖片的內(nèi)容,所以用到了fread()

實(shí)際上,你看到 image.php?id=100 就是顯示這張圖片在瀏覽器上,而你查看源文件,看到的不會(huì)是圖片的路徑,而是亂碼似的圖片內(nèi)容。

類似于qq空間的加密相冊(cè),只有輸入密碼才能訪問(wèn),并且直接在瀏覽器輸入 加密相冊(cè)中的相片地址也是無(wú)法訪問(wèn)。我目前的想法是 圖片的地址是一個(gè)php文件,通過(guò) php 驗(yàn)證權(quán)限 ,讀取圖片,并輸出,不知道除了這樣的方法還有更簡(jiǎn)單高效的做法沒(méi)有?比如生成臨時(shí)的瀏覽地址,使用一些 nginx 的一些防盜鏈插件?
你可以利用ngx_http_auth_basic_module來(lái)完成。

修改配置文件

location / {
root /usr/local/nginx/html;
auth_basic “Auth”;
auth_basic_user_file /usr/local/nginx/conf/htpasswd;
index index.php index.htm;
}

auth_basic “Auth”中的Auth是彈出框(輸入用戶名和密碼)的標(biāo)題

auth_basic_user_file /usr/local/nginx/conf/htpasswd; 中的/usr/local/nginx/conf/htpasswd是保存密碼的文件

以上所述是小編給大家介紹的PHP防止圖片盜用/盜鏈的兩種方法(推薦),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Yii使用DeleteAll連表刪除出現(xiàn)報(bào)錯(cuò)問(wèn)題的解決方法

    Yii使用DeleteAll連表刪除出現(xiàn)報(bào)錯(cuò)問(wèn)題的解決方法

    這篇文章主要介紹了Yii使用DeleteAll連表刪除出現(xiàn)報(bào)錯(cuò)問(wèn)題的解決方法,分析了相關(guān)的SQL語(yǔ)句及出現(xiàn)錯(cuò)誤的原因與改正方法,需要的朋友可以參考下
    2016-07-07
  • destoon實(shí)現(xiàn)首頁(yè)顯示供應(yīng)、企業(yè)、資訊條數(shù)的方法

    destoon實(shí)現(xiàn)首頁(yè)顯示供應(yīng)、企業(yè)、資訊條數(shù)的方法

    這篇文章主要介紹了destoon實(shí)現(xiàn)首頁(yè)顯示供應(yīng)、企業(yè)、資訊條數(shù)的方法,在模板開(kāi)發(fā)中非常實(shí)用,需要的朋友可以參考下
    2014-07-07
  • thinkPHP+phpexcel實(shí)現(xiàn)excel報(bào)表輸出功能示例

    thinkPHP+phpexcel實(shí)現(xiàn)excel報(bào)表輸出功能示例

    這篇文章主要介紹了thinkPHP+phpexcel實(shí)現(xiàn)excel報(bào)表輸出功能,結(jié)合具體實(shí)例形式分析了thinkPHP整合PHPExcel實(shí)現(xiàn)針對(duì)Excel文件相關(guān)操作技巧,需要的朋友可以參考下
    2017-06-06
  • 徹底搞懂PHP 變量結(jié)構(gòu)體

    徹底搞懂PHP 變量結(jié)構(gòu)體

    這篇文章主要介紹了PHP 變量結(jié)構(gòu)體的相關(guān)知識(shí),文中提到了PHP5中的 zval和PHP 7 中的 zval,代碼簡(jiǎn)單易懂,需要的朋友可以參考下
    2017-10-10
  • Laravel服務(wù)容器綁定的幾種方法總結(jié)

    Laravel服務(wù)容器綁定的幾種方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于Laravel服務(wù)容器綁定的幾種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Laravel具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • PHP實(shí)現(xiàn)簡(jiǎn)易計(jì)算器功能

    PHP實(shí)現(xiàn)簡(jiǎn)易計(jì)算器功能

    這篇文章主要為大家詳細(xì)介紹了PHP實(shí)現(xiàn)簡(jiǎn)易計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • laravel實(shí)現(xiàn)簡(jiǎn)單用戶權(quán)限的示例代碼

    laravel實(shí)現(xiàn)簡(jiǎn)單用戶權(quán)限的示例代碼

    這篇文章主要介紹了laravel實(shí)現(xiàn)簡(jiǎn)單用戶權(quán)限的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • php中刪除、清空session的方式總結(jié)

    php中刪除、清空session的方式總結(jié)

    php中刪除session的方式有很多種,本篇文章主要給大家介紹三種清空session的方式,感興趣的朋友跟著小編一起學(xué)習(xí)吧
    2015-10-10
  • Yii框架中jquery表單驗(yàn)證插件用法示例

    Yii框架中jquery表單驗(yàn)證插件用法示例

    這篇文章主要介紹了Yii框架中jquery表單驗(yàn)證插件用法,結(jié)合實(shí)例形式分析了Yii框架中使用jquery表單驗(yàn)證插件進(jìn)行手機(jī)、郵箱等輸入信息驗(yàn)證的相關(guān)操作技巧,需要的朋友可以參考下
    2016-10-10
  • Laravel框架處理用戶的請(qǐng)求操作詳解

    Laravel框架處理用戶的請(qǐng)求操作詳解

    這篇文章主要介紹了Laravel框架處理用戶的請(qǐng)求操作,結(jié)合實(shí)例形式分析了laravel框架請(qǐng)求、響應(yīng)以及中間件、路由等相關(guān)概念與操作技巧,需要的朋友可以參考下
    2019-12-12

最新評(píng)論