php gizp压缩传输js和css文件

1. [代码][PHP]代码    
<?php
 
    /**
     *  完整调用示例:
     *  1、combine.php?t=j&b=public&fs=jslib.jquery,function
     *  
     *  该例子调用的是网站根目录下的public/jslib/jquery.js和public/function.js
 
     *  
     *  2、combine.php?t=j&fs=jslib.jquery,function
     *  
     *  该例子调用的是网站根目录下的jslib/jquery.js和function.js
     *  
     *  3、combine.php?t=c&b=public.css&fs=common,index
     *  
     *  该例子调用的是网站根目录下的public/css/common.css和public/css/index.css
     *  
     *  4、combine.php?t=c&fs=css.common
     *  该例子调用的是网站根目录下的css/common.css
     *  
     *  注:多个文件名之间用,分隔;只有一个文件名最后不要有,
     *     用,分隔的多个文件会被压缩进一个文件,一次性传给浏览器
     **/
    $is_bad_request=false;
    $cache = true;
    $doc_root_uri=$_SERVER[‘DOCUMENT_ROOT‘].‘/‘;
    $cachedir = $doc_root_uri . ‘public/cache‘;
    //文件类型,j为js,c为css
    $type=isset($_GET[‘t‘])?($_GET[‘t‘]==‘j‘||$_GET[‘t‘]==‘c‘?$_GET[‘t‘]:‘‘):‘‘;
     
    //存放js和css文件的基目录, 例如:?b=public.js 代表的是/public/js文件夹,出发点是网站根目录
    //基目录参数不是必须的,如果有基目录那么这个基目录就会附加在文件名之前
    $base =isset($_GET[‘b‘])?($doc_root_uri.str_replace(‘.‘,‘/‘,$_GET[‘b‘])):$doc_root_uri;
     
    //文件名列表,文件名不带后缀名.比如基目录是
    //文件名的格式是 :基目录(如果有)+文件包名+文件名
    //例如:类型是j,
    //     文件名public.js.jquery
    //     如果有基路径且为public,
    //     那么转换后的文件名就是/public/public/js/jquery.js
    //     如果没有基路径
    //     那么转换后的文件名就是/public/js/jquery.js
    //多个文件名之间用,分隔
    $fs=isset($_GET[‘fs‘])?str_replace(‘.‘,‘/‘,$_GET[‘fs‘]):‘‘;
    $fs=str_replace(‘,‘,‘.‘.($type==‘j‘?‘js,‘:‘css,‘),$fs);
    $fs=$fs.($type==‘j‘?‘.js‘:‘.css‘);
     
     
     
    if($type==‘‘||$fs==‘‘){$is_bad_request=true;}
    //die($base);
    ///////////////http://blog.ddian.cn
    if($is_bad_request){header ("HTTP/1.0 503 Not Implemented");}
     
     
    $file_type=$type==‘j‘?‘javascript‘:‘css‘;
     
    $elements = explode(‘,‘,preg_replace(‘/([^?]*).*/‘, ‘\1‘, $fs));
     
    // Determine last modification date of the files
    $lastmodified = 0;
    while (list(,$element) = each($elements)) {
        $path =$base . ‘/‘ . $element;
     
        if (($type == ‘j‘ && substr($path, -3) != ‘.js‘) || 
            ($type == ‘c‘ && substr($path, -4) != ‘.css‘)) {
            header ("HTTP/1.0 403 Forbidden");
            exit;   
        }
     
        if (substr($path, 0, strlen($base)) != $base || !file_exists($path)) {
            header ("HTTP/1.0 404 Not Found");
            exit;
        }
         
        $lastmodified = max($lastmodified, filemtime($path));
    }
     
    // Send Etag hash
    $hash = $lastmodified . ‘-‘ . md5($fs);
    header ("Etag: \"" . $hash . "\"");
     
    if (isset($_SERVER[‘HTTP_IF_NONE_MATCH‘]) && 
        stripslashes($_SERVER[‘HTTP_IF_NONE_MATCH‘]) == ‘"‘ . $hash . ‘"‘) 
    {
        // Return visit and no modifications, so do not send anything
        header ("HTTP/1.0 304 Not Modified");
        header ("Content-Type: text/" . $file_type);
        header (‘Content-Length: 0‘);
    } 
    else
    {
        // First time visit or files were modified
        if ($cache) flash插件
        {?http://www.huiyi8.com/flashchajian/?
            // Determine supported compression method
            $gzip = strstr($_SERVER[‘HTTP_ACCEPT_ENCODING‘], ‘gzip‘);
            $deflate = strstr($_SERVER[‘HTTP_ACCEPT_ENCODING‘], ‘deflate‘);
     
            // Determine used compression method
            $encoding = $gzip ? ‘gzip‘ : ($deflate ? ‘deflate‘ : ‘none‘);
     
            // Check for buggy versions of Internet Explorer
            if (!strstr($_SERVER[‘HTTP_USER_AGENT‘], ‘Opera‘) && 
                preg_match(‘/^Mozilla\/4\.0 \(compatible; MSIE ([0-9]\.[0-9])/i‘, $_SERVER[‘HTTP_USER_AGENT‘], $matches)) {
                $version = floatval($matches[1]);
                 
                if ($version < 6)
                    $encoding = ‘none‘;
                     
                if ($version == 6 && !strstr($_SERVER[‘HTTP_USER_AGENT‘], ‘EV1‘)) 
                    $encoding = ‘none‘;
            }
             
            // Try the cache first to see if the combined files were already generated
            $cachefile = ‘cache-‘ . $hash . ‘.‘ . $file_type . ($encoding != ‘none‘ ? ‘.‘ . $encoding : ‘‘);
             
            if (file_exists($cachedir . ‘/‘ . $cachefile)) {
                if ($fp = fopen($cachedir . ‘/‘ . $cachefile, ‘rb‘)) {
 
                    if ($encoding != ‘none‘) {
                        header ("Content-Encoding: " . $encoding);
                    }
                 
                    header ("Content-Type: text/" . $file_type);
                    header ("Content-Length: " . filesize($cachedir . ‘/‘ . $cachefile));
                    fpassthru($fp);
                    fclose($fp);
                    exit;
                }
            }
        }
     
        // Get contents of the files
        $contents = ‘‘;
        reset($elements);
        while (list(,$element) = each($elements)) {
            $path = $base . ‘/‘ . $element;
            $contents .= "\n\n" . file_get_contents($path);
        }
     
        // Send Content-Type
        header ("Content-Type: text/" . $file_type);
         
        if (isset($encoding) && $encoding != ‘none‘) 
        {
            // Send compressed contents
            $contents = gzencode($contents, 9, $gzip ? FORCE_GZIP : FORCE_DEFLATE);
            header ("Content-Encoding: " . $encoding);
            header (‘Content-Length: ‘ . strlen($contents));
            echo $contents;
        } 
        else
        {
            // Send regular contents
            header (‘Content-Length: ‘ . strlen($contents));
            echo $contents;
        }
 
        // Store cache
        if ($cache) {
            if ($fp = fopen($cachedir . ‘/‘ . $cachefile, ‘wb‘)) {
                fwrite($fp, $contents);
                fclose($fp);
            }
        }
    }

时间: 2024-08-04 17:11:15

php gizp压缩传输js和css文件的相关文章

【翻译】Microsoft Ajax Minifier 快速使用指南(与VS集成使用) 编译后直接压缩项目的JS或CSS文件

网上找了好久终于找到一个能跟VS集成使用的JS和CSS压缩工具,因为害怕忘记,所以给转发过来,顺便翻译一下,大学那会儿学的英语基本上都已经还给老师了,所以翻译的不太好,不过能看懂就成,对吧? 原文地址:http://www.asp.net/ajaxlibrary/AjaxMinQuickStart.ashx 一.在命令行中使用 在下载安装完成Microsoft Ajax Minifier之后,你就可以以命令的方式使用它了.单击“开始”——“所有程序”——“Microsoft Ajax Minif

[转][前端优化]使用Combres合并对js、css文件的请求

本文转自:http://www.cnblogs.com/parry/archive/2011/01/28/Reduce_Http_Request_Using_Combres_For_Js_Css.html 在前端优化的各种金律铁规中,“减少客户端对资源的请求”都会在其中出现,刚好最近对网站做一些优化,使用了一下Combres组件,有点心得,遂整理成文. 园子中也有几篇Combres组件的介绍,如:Combres库学习小结以及部分源码分析和使用Combres 库 ASP.NET 网站优化.可部署时

第十一节:Bundles压缩合并js和css及原理分析

一. 简介 1.背景:浏览器默认一次性请求的网络数是有上限的,如果你得js和css文件太多,就会导致浏览器需要多次加载,影响页面的加载速度, MVC中提供Bundles的方式压缩合并js和css,是MVC中特有的一种优化方式. (当然现在前端也有很多基于node的工作流插件,可以合并压缩混淆js或css) 2. 原理(了解即可):核心方法ApplyTransforms,通过StreamReader不断一次一次进行读取 参考文档:https://docs.microsoft.com/en-us/a

后台修改js或者css文件之后,客户端刷新但是无效的问题

前端开发会遇到一个问题:修改测试前端代码的时候,有时候修改了css或者js文件,但是前端刷新的时候却没有反应,不免让人感觉是不是修改错误,其实这有可能是客户端缓存问题.解决方法: 1)Ctrl+F5,清除浏览器缓存(等同于浏览器-->历史数据-->删除cookies) 2)在js或css后加版本号,这时候浏览器客户端会认为这是不同版本的js或者css文件,会自动重新刷新下载(浏览器会缓存下载页面js和css文件) 2.1)形如:.css?v=x  或者 css?version=x     &l

将js和css文件装入localStorage加速程序执行

原理如下: 一次批量加要加载的文件存入数组,采用Ajax方式异步载入各个文件,然后采用循环方式逐个执行下载下来的Js或者Css文件,如果已经被缓存(localStorage)的则省略下载过程. 由于JS采用的是单线程模式运行,在执行某一个js时会阻塞其它并发的js执行,所以会按顺序执行各个js.在执行完所有的脚本之后,图片会被浏览器接着 加载,所以第一次加载速度略慢,后面就会比较快了.在JQuery Mobile 1.4.5+FireFox/微信浏览器下实测效果不错,IE就被省略了,我主要是要在

2个方法通过字[符串参数]加载外部js和css文件

Java语言的异常处理机制可以去确保程序的健壮性,提高系统的可用率,但是Java API提供的异常都是比较低级的(这里的低级是指 " 低级别的 " 异常),只有开发人员才能看的懂,才明白发生了什么问题.而对于终端用户来说,这些异常基本上就是天书,与业务无关,是纯计算机语言的描述,那该怎么办?这就需要我们对异常进行封装了. 近年来,深度学习的研究越来越深入,在各个领域也都获得了不少突破性的进展.基于注意力(attention)机制的神经网络成为了最近神经网络研究的一个热点,本人最近也学习

gulp-rev同时将js和css文件写在一个rev-manifest.json文件里面的方式探讨

参考: https://segmentfault.com/q/1010000002876613 https://github.com/sindresorhus/gulp-rev 测试发现,在官网上最主要的做法是: 加入如下参数: { base: 'build/assets', merge: true } 其中base为存放上一个生成的rev-manifest.json文件,然后merge为是否拼合进去,最后再输出到base这个目录上,就可以实现js和css文件同在一个rev-manifest.j

引入JS和CSS文件加版本号的作用

形如: <script type="text/javascript" src="/resources/js/myFunction.js?version=0.1.0"></script> <link rel="stylesheet" type="text/css" href="/resources/css/styles/myLocation.css?version=0.1.0"

Django中载入js和css文件

Django中载入js和css文件 项目的文件夹结构例如以下: mysite |-mysite |-|-static |-|---js和css文件 |-|-|-init.py |-| |-models.py |-| |-views.py |-|-init.py |-|-settings.py |-|-urls.py |-templates |-|-(template html 文件) settings.py中static变量的设置: STATIC_ROOT = os.path.join(os.p