Tips:点此可运行HTML源码

如何利用火狐控制台下载网页图片

今天在群里看到一个群友的问题,怎么下载网页的图片,经过一番的演变,得出了本文的成果,也算是一种思路,还可以演变成干很多事,因此写下此文,希望能够对大家有所启发。

问题:

如何从一个网页里下载浏览器加载出来的图片?

思考思路:

1、利用Ctrl+S保存,取出里面的图片
2、通过火狐控制台的网络面板,复制所有图片链接
3、利用控制台执行解析现有html里的img标签,得到它的链接
4、利用第3点得到的链接,直接借助js请求一个代理下载地址,帮忙下载图片文件

本文便是基于第4点实现。

第一步 获取页面图片链接并请求下载文件

获取所有img标签的链接,无论jQuery还是原生javascript都能做到,下面是它们的实现代码:

jQuery版获取页面图片链接并请求下载文件

$("img").each(function(){
    window.open('http://localhost/downloadImg.php?file='+encodeURIComponent($(this).attr("src")));
});

原生javascript版获取页面图片链接并请求下载文件

var tags = document.getElementsByTagName("img");
for (var i = 0; i < tags.length; i++) {
    window.open('http://localhost/downloadImg.php?file='+encodeURIComponent(tags[i].src));
}

第二步 文件代理下载程序

<?php
/**
 * 图片代理下载程序
 * @filename downloadImg.php
 * @author Zjmainstay
 * @website http://www.zjmainstay.cn
 * @usage 存储于http://localhost目录下
 */
$filename = urldecode($_GET['file']);
if(preg_match('#/([^/]+)$#i', $filename, $match)) {
    $dir = dirname(__FILE__) . '/downloadImg/';
    if(!is_dir($dir)) @mkdir($dir, 0755);
    $saveFile = $dir . $match[1];
    file_put_contents($saveFile, file_get_contents($filename));
    echo "Success!";
} else {
    echo "Fail!";
}
//自动关闭窗口程序(打开窗口过多,不友好)
echo '<script type="text/javascript">window.close();</script>';

第三步 实操下载

  1. F12打开火狐Firebug控制台,结果如图(一)所示

火狐控制台运行命令

如果你发现F12打开跟图片不一样,那么你需要安装Firebug:
菜单-工具-附加组件-右上角搜索"Firebug"-安装(Ctrl+Shift+A可快速打开附加组件窗口)

  1. 输入第一步的js代码并运行,结果如图(二)所示

火狐控制台运行命令获取图片链接并下载

  1. 查看http://localhost目录下的downloadImg目录,结果如图(三)所示

下载文件列表

附:重要提示

这个代理下载功能(downloadImg.php)切不可对外开放,否则可能被人利用,代理下载携带php后门的图片文件,再结合其他的漏洞利用攻击你的服务器。

(本文完)

转载请附带本文原文地址:如何利用火狐控制台实现网页图片下载,首发自 Zjmainstay学习笔记

posted @   Zjmainstay  阅读(3783)  评论(3编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示