扒网站当中一般css中的图片扒不下来,这个脚本就是用来下载这些图片到本地的

流程

    1、获取css文件路径

    2、打开文件逐行读取判断是否包含需要的图片

      2.1 包含则 -进行截取直接获取到相对路径

        2.1.1 根据curl来文件流,fopne打开文件,fwrite写入文件

      2.2不包含则跳出

<?php
/**
* Created by PhpStorm.
* User: 小狗蛋儿
* Date: 2018/3/19
* Time: 14:39
*
* 获取css文件下面所有的css文件
* 然后替换所有的background
*/ $dirname=dirname("D:\\ibwant\\new.css-13.css"); $root_url="xxxxxx"; //网站根目录 $rege="";
if (!is_dir($dirname)){
echo "不是目录".$dirname;
}else { $file=array(); $scandir = scandir($dirname);
foreach ($scandir as $value){
if (getExtends($value)=="css"){ $handle = fopen ($dirname."\\".$value, "r");
GetsSave($handle,$value); }else{
continue;
} }
} /**
* @param $files
* @return mixed
* 出现的位置
*/
function getExtends($files){
return pathinfo($files, PATHINFO_EXTENSION);
} /**
* @param $opens
* @param $names
* 获取指定文件的位置
*/
function GetsSave($opens,$names){
$fl=array();
//feof 判断检测文件是否到末尾
while(!feof($opens)){
$contents=fgets($opens);
if(strstr($contents,"/*tpa=")){
$fl[]=substr($contents,strpos($contents,"=")+1); }else{
continue;
}
}
getDows($fl);
fclose($opens);
} // $s="xxxx";
// echo strpos($s,"*"); function getDows($as){
$cas=array();
foreach ($as as $value){ if (substr($value,0,4)!="http"){
continue;
}else {
$nums = strpos($value, "*");
$cas[] = substr($value, 0, $nums);
}
}
Saveimg($cas); } function Saveimg($ims){
foreach ($ims as $values){
$contens=trim(strrchr($values,"/"),"/"); // $filenames=substr($contens,0,strpos($contens,"."));
$return_content = http_get_data($values);
//var_dump($return_content); $fp= @fopen($contens,"a");
fwrite($fp,$return_content); } } function http_get_data($url){
$ch=curl_init();
curl_setopt ( $ch, CURLOPT_CUSTOMREQUEST, 'GET' );
curl_setopt ( $ch, CURLOPT_SSL_VERIFYPEER, false );
curl_setopt ( $ch, CURLOPT_URL, $url );
ob_start ();
curl_exec ( $ch );
$return_content = ob_get_contents ();
ob_end_clean (); $return_code = curl_getinfo ( $ch, CURLINFO_HTTP_CODE );
return $return_content;
}

PHP修改css文件中的背景图片并下载到本地的更多相关文章

  1. css网页中设置背景图片的方法详解

    在css代码中设置背景图片的方法,包括背景图片.背景重复.背景固定.背景定位等   用css设置网页中的背景图片,主要有如下几个属性: 1,背景颜色 {">说明:参数取值和颜色属性一样 ...

  2. vue webpack打包后.css文件里面的背景图片路径错误解决方法

    资源相对引用路径 问题描述 一般情况下,通过webpack+vuecli默认打包的css.js等资源,路径都是绝对的. 但当部署到带有文件夹的项目中,这种绝对路径就会出现问题,因为把配置的static ...

  3. 动态修改css文件中,具体的class中的个别属性值。

    function setStyleSheetObjCssClassProperty(pStyleSheetObj, pSelectorText, pProperty, pValue) { var pS ...

  4. css文件 如何使背景图片大小适应div的大小

    对背景图片设置属性:background-size:cover;可以实现背景图片适应div的大小. background-size有3个属性: auto:当使用该属性的时候,背景图片将保持100% 的 ...

  5. HTML 或 CSS 文件中引用的图片文件移动到任意位置

    对于一个套接字的输入操作,第一步通常涉及等待数据从网络到达,当所等待分组到达时,被复制到内核的某个缓冲区: 第二步就是把数据从内核缓冲区复制到应用进程缓冲区.通过 Session 的 createQu ...

  6. Taro,实现小程序在样式文件中导入背景图片

    https://taro-docs.jd.com/taro/docs/static-reference.html 注意点是,控制你的图片大小,然后配置完limit后,把dist删掉,重新运行 npm ...

  7. CSS样式中,background-image 背景图片居中显示并且在不同屏幕分辨率下始终居中

    body {   margin-top:0px; margin-right:0px;   margin-bottom:0px;   margin-left:0px;   background-colo ...

  8. 用extract-text-webpack-plugin提取出来的css文件中背景图片url的不正确的问题

    在一个main.js中require一个scss文件,scss文件中用了背景图片,图片url是用的相对路径,用extract-text-webpack-plugin插件提取出的css文件背景图片路径不 ...

  9. Vue项目打包发布后CSS中的背景图片不显示

    相信有很多同学在学习vue的刚开始都遇到过项目打包发布后发现CSS中的背景图片不显示,具体如何解决只需要更改bind的配置即可 修改 build/utils.js 中的 generateLoaders ...

随机推荐

  1. c语言 static的用法

    static在c里面可以用来修饰变量,也可以用来修饰函数.先看用来修饰变量的时候.变量在c里面可分为存在全局数据区.栈和堆里.其实我们平时所说的堆栈是栈而不是堆,不要弄混.int a ;int mai ...

  2. 配置adpate的方式

    配置adpate的方式 资源文件配置 ArryAdapter<CharSequence>cadapt= ArryAdapter.createFromResource(this,资源id,a ...

  3. Python 3.9 新特性速览

    国庆假期,Python 社区发布了 3.9 版本的第一个 stable release. 相比于 3.8,Python 3.9 新特性众多,但不少特性与大多数 Python"使用者" ...

  4. ConcurrentHashMap源码解析,多线程扩容

    前面一篇已经介绍过了 HashMap 的源码: HashMap源码解析.jdk7和8之后的区别.相关问题分析 HashMap并不是线程安全的,他就一个普通的容器,没有做相关的同步处理,因此线程不安全主 ...

  5. tmpwatch命令清除旧文件

    我们知道系统里面常常会有一些忘记删除的长时间不用而且确实没有用处的文件,如果不去处理,这些无用的文件会越来越多,浪费许多系统资源.在不知道文件名的情况下,很难去检查某一目录下到底是哪些文件长时间没有被 ...

  6. 配置DVWA漏洞环境

    web萌新,因为在别人的环境上练习总有点不舒服,所以在本地搭建了网站:下面记录一下搭建的步骤 DVWA:是一个漏洞环境包,可以用phpstudy或者wamp解析:所以要想配置这个环境,就必须有这两个软 ...

  7. 使用git 版本控制的代码在线修调试,如何还原

    在线调试: 先切换成www用户进入项目的根目录比如/data/wwwroot/website su www cd /data/wwwroot/website vi ./api/controllers/ ...

  8. CyclicBarrier原来是这样的

    上一篇聊了一下Semaphore信号灯的用法及源码,这一篇来聊一下CyclicBarrier的用法及解析. 官网解释: 允许一组线程全部等待彼此达到共同屏障点的同步辅助.循环阻塞在涉及固定大小的线程方 ...

  9. 多测师讲解接口测试_F12中network里headers各项属性的含义——高级讲师肖sir

    General部分: Request URL:资源的请求url # Request Method:HTTP方法  Status Code:响应状态码  200(状态码) OK 301 - 资源(网页等 ...

  10. Gradle的构建过程都不会?带你全面了解Android如何自定义Gradle 插件

    目前 Android 工程的默认构建工具为 Gradle,我们在构建 APK 的时候往往会执行 ./gradlew assembleDebug 这样的命令.. 那么这个命令到底代表着什么含义呢?命令的 ...