怎么禁止图片直接通过url访问

从不吃馍 2017-06-16 12:10:59
我在被人网站看到这样的示例,审查元素有图片路径,但是直接把图片路径复制下来粘贴到浏览器访问却跳转到默认图片

这是图片url,大家可以复制试试
http://z1.xiu.top/uploadfiles/349/30264f6f9d82cff5/e75829353a51d05e.png
请问这样的功能是怎么做出来的,我的是php,iis环境
...全文
1658 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
傲雪星枫 2017-06-17
  • 打赏
  • 举报
回复
你图片的路径放在web不能直接访问的目录。
例如你域名根目录是/home/www
那么你的图片路径可以放在 /home/photo
读取图片使用php去读例如,img.php,然后在php中判断来源

<?php
$referer = $_SERVER['HTTP_REFERER'];
if(!strpos($referer, 'http://你的域名')===0){
exit('盗连');
}
$data = file_get_contents('/home/photo/1.jpg');
header('content-type:image/jpeg');
echo $data;
?>

访问img.php才可以读到图片。


如果简单点可以判断访问来源,可以在web服务器中判断处理。
例如
http://www.jb51.net/os/RedHat/1060.html
jacksq 2017-06-17
  • 打赏
  • 举报
回复
这样做会不会把百度等搜索引擎也给挡了?
pharaoh_shi 2017-06-17
  • 打赏
  • 举报
回复
写一个 robots.txt 文件
果酱很好吃 2017-06-16
  • 打赏
  • 举报
回复
简单防盗链 web服务器里面就可以做,当然 iis 也可以
xuzuning 2017-06-16
  • 打赏
  • 举报
回复
经测试,的确如此

我的 curl 里有
$t = parse_url($durl);
curl_setopt($ch, CURLOPT_REFERER, "http://$t[host]/");

不发送来源信息,就是
xuzuning 2017-06-16
  • 打赏
  • 举报
回复
判断请求来源

21,894

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧